1{
2    "smithy": "1.0",
3    "metadata": {
4        "suppressions": [
5            {
6                "id": "HttpMethodSemantics",
7                "namespace": "*"
8            },
9            {
10                "id": "HttpResponseCodeSemantics",
11                "namespace": "*"
12            },
13            {
14                "id": "PaginatedTrait",
15                "namespace": "*"
16            },
17            {
18                "id": "HttpHeaderTrait",
19                "namespace": "*"
20            },
21            {
22                "id": "HttpUriConflict",
23                "namespace": "*"
24            },
25            {
26                "id": "Service",
27                "namespace": "*"
28            }
29        ]
30    },
31    "shapes": {
32        "com.amazonaws.emrcontainers#ACMCertArn": {
33            "type": "string",
34            "traits": {
35                "smithy.api#length": {
36                    "min": 44,
37                    "max": 2048
38                },
39                "smithy.api#pattern": "^arn:(aws[a-zA-Z0-9-]*):acm:.+:(\\d{12}):certificate/.+$"
40            }
41        },
42        "com.amazonaws.emrcontainers#AwsChicagoWebService": {
43            "type": "service",
44            "version": "2020-10-01",
45            "operations": [
46                {
47                    "target": "com.amazonaws.emrcontainers#CancelJobRun"
48                },
49                {
50                    "target": "com.amazonaws.emrcontainers#CreateManagedEndpoint"
51                },
52                {
53                    "target": "com.amazonaws.emrcontainers#CreateVirtualCluster"
54                },
55                {
56                    "target": "com.amazonaws.emrcontainers#DeleteManagedEndpoint"
57                },
58                {
59                    "target": "com.amazonaws.emrcontainers#DeleteVirtualCluster"
60                },
61                {
62                    "target": "com.amazonaws.emrcontainers#DescribeJobRun"
63                },
64                {
65                    "target": "com.amazonaws.emrcontainers#DescribeManagedEndpoint"
66                },
67                {
68                    "target": "com.amazonaws.emrcontainers#DescribeVirtualCluster"
69                },
70                {
71                    "target": "com.amazonaws.emrcontainers#ListJobRuns"
72                },
73                {
74                    "target": "com.amazonaws.emrcontainers#ListManagedEndpoints"
75                },
76                {
77                    "target": "com.amazonaws.emrcontainers#ListTagsForResource"
78                },
79                {
80                    "target": "com.amazonaws.emrcontainers#ListVirtualClusters"
81                },
82                {
83                    "target": "com.amazonaws.emrcontainers#StartJobRun"
84                },
85                {
86                    "target": "com.amazonaws.emrcontainers#TagResource"
87                },
88                {
89                    "target": "com.amazonaws.emrcontainers#UntagResource"
90                }
91            ],
92            "traits": {
93                "aws.api#service": {
94                    "sdkId": "EMR containers",
95                    "arnNamespace": "emr-containers",
96                    "cloudFormationName": "EMRcontainers",
97                    "cloudTrailEventSource": "emrcontainers.amazonaws.com",
98                    "endpointPrefix": "emr-containers"
99                },
100                "aws.auth#sigv4": {
101                    "name": "emr-containers"
102                },
103                "aws.protocols#restJson1": {},
104                "smithy.api#documentation": "<p>Amazon EMR on EKS provides a deployment option for Amazon EMR that allows you to run\n         open-source big data frameworks on Amazon Elastic Kubernetes Service (Amazon EKS). With\n         this deployment option, you can focus on running analytics workloads while Amazon EMR on\n         EKS builds, configures, and manages containers for open-source applications. For more\n         information about Amazon EMR on EKS concepts and tasks, see <a href=\"https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/emr-eks.html\">What is Amazon EMR on EKS</a>.</p>\n         <p>\n            <i>Amazon EMR containers</i> is the API name for Amazon EMR on EKS. The\n            <code>emr-containers</code> prefix is used in the following scenarios: </p>\n         <ul>\n            <li>\n               <p>It is the prefix in the CLI commands for Amazon EMR on EKS. For example, <code>aws\n                  emr-containers start-job-run</code>.</p>\n            </li>\n            <li>\n               <p>It is the prefix before IAM policy actions for Amazon EMR on EKS. For example, <code>\"Action\": [\n            \"emr-containers:StartJobRun\"]</code>. For more information, see <a href=\"https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-actions\">Policy actions for Amazon EMR on EKS</a>.</p>\n            </li>\n            <li>\n               <p>It is the prefix used in Amazon EMR on EKS service endpoints. For example, <code>emr-containers.us-east-2.amazonaws.com</code>. For more\n            information, see <a href=\"https://docs.aws.amazon.com/emr/latest/EMR-on-EKS-DevelopmentGuide/service-quotas.html#service-endpoints\">Amazon EMR on EKS Service Endpoints</a>.</p>\n            </li>\n         </ul>",
105                "smithy.api#title": "Amazon EMR Containers"
106            }
107        },
108        "com.amazonaws.emrcontainers#CancelJobRun": {
109            "type": "operation",
110            "input": {
111                "target": "com.amazonaws.emrcontainers#CancelJobRunRequest"
112            },
113            "output": {
114                "target": "com.amazonaws.emrcontainers#CancelJobRunResponse"
115            },
116            "errors": [
117                {
118                    "target": "com.amazonaws.emrcontainers#InternalServerException"
119                },
120                {
121                    "target": "com.amazonaws.emrcontainers#ValidationException"
122                }
123            ],
124            "traits": {
125                "smithy.api#documentation": "<p>Cancels a job run. A job run is a unit of work, such as a Spark jar, PySpark script, or SparkSQL query, that you submit to Amazon EMR on EKS.</p>",
126                "smithy.api#http": {
127                    "method": "DELETE",
128                    "uri": "/virtualclusters/{virtualClusterId}/jobruns/{id}",
129                    "code": 200
130                }
131            }
132        },
133        "com.amazonaws.emrcontainers#CancelJobRunRequest": {
134            "type": "structure",
135            "members": {
136                "id": {
137                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
138                    "traits": {
139                        "smithy.api#documentation": "<p>The ID of the job run to cancel.</p>",
140                        "smithy.api#httpLabel": {},
141                        "smithy.api#required": {}
142                    }
143                },
144                "virtualClusterId": {
145                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
146                    "traits": {
147                        "smithy.api#documentation": "<p>The ID of the virtual cluster for which the job run will be canceled.</p>",
148                        "smithy.api#httpLabel": {},
149                        "smithy.api#required": {}
150                    }
151                }
152            }
153        },
154        "com.amazonaws.emrcontainers#CancelJobRunResponse": {
155            "type": "structure",
156            "members": {
157                "id": {
158                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
159                    "traits": {
160                        "smithy.api#documentation": "<p>The output contains the ID of the cancelled job run.</p>"
161                    }
162                },
163                "virtualClusterId": {
164                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
165                    "traits": {
166                        "smithy.api#documentation": "<p>The output contains the virtual cluster ID for which the job run is cancelled.</p>"
167                    }
168                }
169            }
170        },
171        "com.amazonaws.emrcontainers#ClientToken": {
172            "type": "string",
173            "traits": {
174                "smithy.api#length": {
175                    "min": 1,
176                    "max": 64
177                },
178                "smithy.api#pattern": ".*\\S.*"
179            }
180        },
181        "com.amazonaws.emrcontainers#CloudWatchMonitoringConfiguration": {
182            "type": "structure",
183            "members": {
184                "logGroupName": {
185                    "target": "com.amazonaws.emrcontainers#LogGroupName",
186                    "traits": {
187                        "smithy.api#documentation": "<p>The name of the log group for log publishing.</p>",
188                        "smithy.api#required": {}
189                    }
190                },
191                "logStreamNamePrefix": {
192                    "target": "com.amazonaws.emrcontainers#String256",
193                    "traits": {
194                        "smithy.api#documentation": "<p>The specified name prefix for log streams.</p>"
195                    }
196                }
197            },
198            "traits": {
199                "smithy.api#documentation": "<p>A configuration for CloudWatch monitoring. You can configure your jobs to send log information to CloudWatch Logs.</p>"
200            }
201        },
202        "com.amazonaws.emrcontainers#Configuration": {
203            "type": "structure",
204            "members": {
205                "classification": {
206                    "target": "com.amazonaws.emrcontainers#String1024",
207                    "traits": {
208                        "smithy.api#documentation": "<p>The classification within a configuration.</p>",
209                        "smithy.api#required": {}
210                    }
211                },
212                "properties": {
213                    "target": "com.amazonaws.emrcontainers#SensitivePropertiesMap",
214                    "traits": {
215                        "smithy.api#documentation": "<p>A set of properties specified within a configuration classification.</p>"
216                    }
217                },
218                "configurations": {
219                    "target": "com.amazonaws.emrcontainers#ConfigurationList",
220                    "traits": {
221                        "smithy.api#documentation": "<p>A list of additional configurations to apply within a configuration object.</p>"
222                    }
223                }
224            },
225            "traits": {
226                "smithy.api#documentation": "<p>A configuration specification to be used when provisioning virtual clusters, which can include configurations for applications and software bundled with Amazon EMR on EKS. A configuration consists of a classification, properties, and optional nested configurations. A classification refers to an application-specific configuration file. Properties are the settings you want to change in that file.</p>"
227            }
228        },
229        "com.amazonaws.emrcontainers#ConfigurationList": {
230            "type": "list",
231            "member": {
232                "target": "com.amazonaws.emrcontainers#Configuration"
233            },
234            "traits": {
235                "smithy.api#length": {
236                    "min": 0,
237                    "max": 100
238                }
239            }
240        },
241        "com.amazonaws.emrcontainers#ConfigurationOverrides": {
242            "type": "structure",
243            "members": {
244                "applicationConfiguration": {
245                    "target": "com.amazonaws.emrcontainers#ConfigurationList",
246                    "traits": {
247                        "smithy.api#documentation": "<p>The configurations for the application running by the job run. </p>"
248                    }
249                },
250                "monitoringConfiguration": {
251                    "target": "com.amazonaws.emrcontainers#MonitoringConfiguration",
252                    "traits": {
253                        "smithy.api#documentation": "<p>The configurations for monitoring.</p>"
254                    }
255                }
256            },
257            "traits": {
258                "smithy.api#documentation": "<p>A configuration specification to be used to override existing configurations.</p>"
259            }
260        },
261        "com.amazonaws.emrcontainers#ContainerInfo": {
262            "type": "union",
263            "members": {
264                "eksInfo": {
265                    "target": "com.amazonaws.emrcontainers#EksInfo",
266                    "traits": {
267                        "smithy.api#documentation": "<p>The information about the EKS cluster.</p>"
268                    }
269                }
270            },
271            "traits": {
272                "smithy.api#documentation": "<p>The information about the container used for a job run or a managed endpoint.</p>"
273            }
274        },
275        "com.amazonaws.emrcontainers#ContainerProvider": {
276            "type": "structure",
277            "members": {
278                "type": {
279                    "target": "com.amazonaws.emrcontainers#ContainerProviderType",
280                    "traits": {
281                        "smithy.api#documentation": "<p>The type of the container provider. EKS is the only supported type as of now.</p>",
282                        "smithy.api#required": {}
283                    }
284                },
285                "id": {
286                    "target": "com.amazonaws.emrcontainers#String256",
287                    "traits": {
288                        "smithy.api#documentation": "<p>The ID of the container cluster.</p>",
289                        "smithy.api#required": {}
290                    }
291                },
292                "info": {
293                    "target": "com.amazonaws.emrcontainers#ContainerInfo",
294                    "traits": {
295                        "smithy.api#documentation": "<p>The information about the container cluster.</p>"
296                    }
297                }
298            },
299            "traits": {
300                "smithy.api#documentation": "<p>The information about the container provider.</p>"
301            }
302        },
303        "com.amazonaws.emrcontainers#ContainerProviderType": {
304            "type": "string",
305            "traits": {
306                "smithy.api#enum": [
307                    {
308                        "value": "EKS",
309                        "name": "EKS"
310                    }
311                ]
312            }
313        },
314        "com.amazonaws.emrcontainers#CreateManagedEndpoint": {
315            "type": "operation",
316            "input": {
317                "target": "com.amazonaws.emrcontainers#CreateManagedEndpointRequest"
318            },
319            "output": {
320                "target": "com.amazonaws.emrcontainers#CreateManagedEndpointResponse"
321            },
322            "errors": [
323                {
324                    "target": "com.amazonaws.emrcontainers#InternalServerException"
325                },
326                {
327                    "target": "com.amazonaws.emrcontainers#ResourceNotFoundException"
328                },
329                {
330                    "target": "com.amazonaws.emrcontainers#ValidationException"
331                }
332            ],
333            "traits": {
334                "smithy.api#documentation": "<p>Creates a managed endpoint. A managed endpoint is a gateway that connects EMR Studio to Amazon EMR on EKS so that EMR Studio can communicate with your virtual cluster.</p>",
335                "smithy.api#http": {
336                    "method": "POST",
337                    "uri": "/virtualclusters/{virtualClusterId}/endpoints",
338                    "code": 200
339                }
340            }
341        },
342        "com.amazonaws.emrcontainers#CreateManagedEndpointRequest": {
343            "type": "structure",
344            "members": {
345                "name": {
346                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
347                    "traits": {
348                        "smithy.api#documentation": "<p>The name of the managed endpoint.</p>",
349                        "smithy.api#required": {}
350                    }
351                },
352                "virtualClusterId": {
353                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
354                    "traits": {
355                        "smithy.api#documentation": "<p>The ID of the virtual cluster for which a managed endpoint is created.</p>",
356                        "smithy.api#httpLabel": {},
357                        "smithy.api#required": {}
358                    }
359                },
360                "type": {
361                    "target": "com.amazonaws.emrcontainers#EndpointType",
362                    "traits": {
363                        "smithy.api#documentation": "<p>The type of the managed endpoint.</p>",
364                        "smithy.api#required": {}
365                    }
366                },
367                "releaseLabel": {
368                    "target": "com.amazonaws.emrcontainers#ReleaseLabel",
369                    "traits": {
370                        "smithy.api#documentation": "<p>The Amazon EMR release version.</p>",
371                        "smithy.api#required": {}
372                    }
373                },
374                "executionRoleArn": {
375                    "target": "com.amazonaws.emrcontainers#IAMRoleArn",
376                    "traits": {
377                        "smithy.api#documentation": "<p>The ARN of the execution role.</p>",
378                        "smithy.api#required": {}
379                    }
380                },
381                "certificateArn": {
382                    "target": "com.amazonaws.emrcontainers#ACMCertArn",
383                    "traits": {
384                        "smithy.api#documentation": "<p>The certificate ARN of the managed endpoint.</p>",
385                        "smithy.api#required": {}
386                    }
387                },
388                "configurationOverrides": {
389                    "target": "com.amazonaws.emrcontainers#ConfigurationOverrides",
390                    "traits": {
391                        "smithy.api#documentation": "<p>The configuration settings that will be used to override existing configurations.</p>"
392                    }
393                },
394                "clientToken": {
395                    "target": "com.amazonaws.emrcontainers#ClientToken",
396                    "traits": {
397                        "smithy.api#documentation": "<p>The client idempotency token for this create call.</p>",
398                        "smithy.api#idempotencyToken": {},
399                        "smithy.api#required": {}
400                    }
401                },
402                "tags": {
403                    "target": "com.amazonaws.emrcontainers#TagMap",
404                    "traits": {
405                        "smithy.api#documentation": "<p>The tags of the managed endpoint.\n      </p>"
406                    }
407                }
408            }
409        },
410        "com.amazonaws.emrcontainers#CreateManagedEndpointResponse": {
411            "type": "structure",
412            "members": {
413                "id": {
414                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
415                    "traits": {
416                        "smithy.api#documentation": "<p>The output contains the ID of the managed endpoint.</p>"
417                    }
418                },
419                "name": {
420                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
421                    "traits": {
422                        "smithy.api#documentation": "<p>The output contains the name of the managed endpoint.</p>"
423                    }
424                },
425                "arn": {
426                    "target": "com.amazonaws.emrcontainers#EndpointArn",
427                    "traits": {
428                        "smithy.api#documentation": "<p>The output contains the ARN of the managed endpoint.</p>"
429                    }
430                },
431                "virtualClusterId": {
432                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
433                    "traits": {
434                        "smithy.api#documentation": "<p>The output contains the ID of the virtual cluster.</p>"
435                    }
436                }
437            }
438        },
439        "com.amazonaws.emrcontainers#CreateVirtualCluster": {
440            "type": "operation",
441            "input": {
442                "target": "com.amazonaws.emrcontainers#CreateVirtualClusterRequest"
443            },
444            "output": {
445                "target": "com.amazonaws.emrcontainers#CreateVirtualClusterResponse"
446            },
447            "errors": [
448                {
449                    "target": "com.amazonaws.emrcontainers#InternalServerException"
450                },
451                {
452                    "target": "com.amazonaws.emrcontainers#ResourceNotFoundException"
453                },
454                {
455                    "target": "com.amazonaws.emrcontainers#ValidationException"
456                }
457            ],
458            "traits": {
459                "smithy.api#documentation": "<p>Creates a virtual cluster. Virtual cluster is a managed entity on Amazon EMR on EKS. You can create, describe, list and delete virtual clusters. They do not consume any additional resource in your system. A single virtual cluster maps to a single Kubernetes namespace. Given this relationship, you can model virtual clusters the same way you model Kubernetes namespaces to meet your requirements.</p>",
460                "smithy.api#http": {
461                    "method": "POST",
462                    "uri": "/virtualclusters",
463                    "code": 200
464                }
465            }
466        },
467        "com.amazonaws.emrcontainers#CreateVirtualClusterRequest": {
468            "type": "structure",
469            "members": {
470                "name": {
471                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
472                    "traits": {
473                        "smithy.api#documentation": "<p>The specified name of the virtual cluster.</p>",
474                        "smithy.api#required": {}
475                    }
476                },
477                "containerProvider": {
478                    "target": "com.amazonaws.emrcontainers#ContainerProvider",
479                    "traits": {
480                        "smithy.api#documentation": "<p>The container provider of the virtual cluster.</p>",
481                        "smithy.api#required": {}
482                    }
483                },
484                "clientToken": {
485                    "target": "com.amazonaws.emrcontainers#ClientToken",
486                    "traits": {
487                        "smithy.api#documentation": "<p>The client token of the virtual cluster.</p>",
488                        "smithy.api#idempotencyToken": {},
489                        "smithy.api#required": {}
490                    }
491                },
492                "tags": {
493                    "target": "com.amazonaws.emrcontainers#TagMap",
494                    "traits": {
495                        "smithy.api#documentation": "<p>The tags assigned to the virtual cluster.</p>"
496                    }
497                }
498            }
499        },
500        "com.amazonaws.emrcontainers#CreateVirtualClusterResponse": {
501            "type": "structure",
502            "members": {
503                "id": {
504                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
505                    "traits": {
506                        "smithy.api#documentation": "<p>This output contains the virtual cluster ID.</p>"
507                    }
508                },
509                "name": {
510                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
511                    "traits": {
512                        "smithy.api#documentation": "<p>This output contains the name of the virtual cluster.</p>"
513                    }
514                },
515                "arn": {
516                    "target": "com.amazonaws.emrcontainers#VirtualClusterArn",
517                    "traits": {
518                        "smithy.api#documentation": "<p>This output contains the ARN of virtual cluster.</p>"
519                    }
520                }
521            }
522        },
523        "com.amazonaws.emrcontainers#Date": {
524            "type": "timestamp"
525        },
526        "com.amazonaws.emrcontainers#DeleteManagedEndpoint": {
527            "type": "operation",
528            "input": {
529                "target": "com.amazonaws.emrcontainers#DeleteManagedEndpointRequest"
530            },
531            "output": {
532                "target": "com.amazonaws.emrcontainers#DeleteManagedEndpointResponse"
533            },
534            "errors": [
535                {
536                    "target": "com.amazonaws.emrcontainers#InternalServerException"
537                },
538                {
539                    "target": "com.amazonaws.emrcontainers#ValidationException"
540                }
541            ],
542            "traits": {
543                "smithy.api#documentation": "<p>Deletes a managed endpoint. A managed endpoint is a gateway that connects EMR Studio to Amazon EMR on EKS so that EMR Studio can communicate with your virtual cluster.</p>",
544                "smithy.api#http": {
545                    "method": "DELETE",
546                    "uri": "/virtualclusters/{virtualClusterId}/endpoints/{id}",
547                    "code": 200
548                }
549            }
550        },
551        "com.amazonaws.emrcontainers#DeleteManagedEndpointRequest": {
552            "type": "structure",
553            "members": {
554                "id": {
555                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
556                    "traits": {
557                        "smithy.api#documentation": "<p>The ID of the managed endpoint.</p>",
558                        "smithy.api#httpLabel": {},
559                        "smithy.api#required": {}
560                    }
561                },
562                "virtualClusterId": {
563                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
564                    "traits": {
565                        "smithy.api#documentation": "<p>The ID of the endpoint's virtual cluster.</p>",
566                        "smithy.api#httpLabel": {},
567                        "smithy.api#required": {}
568                    }
569                }
570            }
571        },
572        "com.amazonaws.emrcontainers#DeleteManagedEndpointResponse": {
573            "type": "structure",
574            "members": {
575                "id": {
576                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
577                    "traits": {
578                        "smithy.api#documentation": "<p>The output displays the ID of the managed endpoint.</p>"
579                    }
580                },
581                "virtualClusterId": {
582                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
583                    "traits": {
584                        "smithy.api#documentation": "<p>The output displays the ID of the endpoint's virtual cluster.</p>"
585                    }
586                }
587            }
588        },
589        "com.amazonaws.emrcontainers#DeleteVirtualCluster": {
590            "type": "operation",
591            "input": {
592                "target": "com.amazonaws.emrcontainers#DeleteVirtualClusterRequest"
593            },
594            "output": {
595                "target": "com.amazonaws.emrcontainers#DeleteVirtualClusterResponse"
596            },
597            "errors": [
598                {
599                    "target": "com.amazonaws.emrcontainers#InternalServerException"
600                },
601                {
602                    "target": "com.amazonaws.emrcontainers#ValidationException"
603                }
604            ],
605            "traits": {
606                "smithy.api#documentation": "<p>Deletes a virtual cluster. Virtual cluster is a managed entity on Amazon EMR on EKS. You can create, describe, list and delete virtual clusters. They do not consume any additional resource in your system. A single virtual cluster maps to a single Kubernetes namespace. Given this relationship, you can model virtual clusters the same way you model Kubernetes namespaces to meet your requirements.</p>",
607                "smithy.api#http": {
608                    "method": "DELETE",
609                    "uri": "/virtualclusters/{id}",
610                    "code": 200
611                }
612            }
613        },
614        "com.amazonaws.emrcontainers#DeleteVirtualClusterRequest": {
615            "type": "structure",
616            "members": {
617                "id": {
618                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
619                    "traits": {
620                        "smithy.api#documentation": "<p>The ID of the virtual cluster that will be deleted.</p>",
621                        "smithy.api#httpLabel": {},
622                        "smithy.api#required": {}
623                    }
624                }
625            }
626        },
627        "com.amazonaws.emrcontainers#DeleteVirtualClusterResponse": {
628            "type": "structure",
629            "members": {
630                "id": {
631                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
632                    "traits": {
633                        "smithy.api#documentation": "<p>This output contains the ID of the virtual cluster that will be deleted. </p>"
634                    }
635                }
636            }
637        },
638        "com.amazonaws.emrcontainers#DescribeJobRun": {
639            "type": "operation",
640            "input": {
641                "target": "com.amazonaws.emrcontainers#DescribeJobRunRequest"
642            },
643            "output": {
644                "target": "com.amazonaws.emrcontainers#DescribeJobRunResponse"
645            },
646            "errors": [
647                {
648                    "target": "com.amazonaws.emrcontainers#InternalServerException"
649                },
650                {
651                    "target": "com.amazonaws.emrcontainers#ResourceNotFoundException"
652                },
653                {
654                    "target": "com.amazonaws.emrcontainers#ValidationException"
655                }
656            ],
657            "traits": {
658                "smithy.api#documentation": "<p>Displays detailed information about a job run. A job run is a unit of work, such as a Spark jar, PySpark script, or SparkSQL query, that you submit to Amazon EMR on EKS.</p>",
659                "smithy.api#http": {
660                    "method": "GET",
661                    "uri": "/virtualclusters/{virtualClusterId}/jobruns/{id}",
662                    "code": 200
663                }
664            }
665        },
666        "com.amazonaws.emrcontainers#DescribeJobRunRequest": {
667            "type": "structure",
668            "members": {
669                "id": {
670                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
671                    "traits": {
672                        "smithy.api#documentation": "<p>The ID of the job run request. </p>",
673                        "smithy.api#httpLabel": {},
674                        "smithy.api#required": {}
675                    }
676                },
677                "virtualClusterId": {
678                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
679                    "traits": {
680                        "smithy.api#documentation": "<p>The ID of the virtual cluster for which the job run is submitted.</p>",
681                        "smithy.api#httpLabel": {},
682                        "smithy.api#required": {}
683                    }
684                }
685            }
686        },
687        "com.amazonaws.emrcontainers#DescribeJobRunResponse": {
688            "type": "structure",
689            "members": {
690                "jobRun": {
691                    "target": "com.amazonaws.emrcontainers#JobRun",
692                    "traits": {
693                        "smithy.api#documentation": "<p>The output displays information about a job run.</p>"
694                    }
695                }
696            }
697        },
698        "com.amazonaws.emrcontainers#DescribeManagedEndpoint": {
699            "type": "operation",
700            "input": {
701                "target": "com.amazonaws.emrcontainers#DescribeManagedEndpointRequest"
702            },
703            "output": {
704                "target": "com.amazonaws.emrcontainers#DescribeManagedEndpointResponse"
705            },
706            "errors": [
707                {
708                    "target": "com.amazonaws.emrcontainers#InternalServerException"
709                },
710                {
711                    "target": "com.amazonaws.emrcontainers#ResourceNotFoundException"
712                },
713                {
714                    "target": "com.amazonaws.emrcontainers#ValidationException"
715                }
716            ],
717            "traits": {
718                "smithy.api#documentation": "<p>Displays detailed information about a managed endpoint. A managed endpoint is a gateway that connects EMR Studio to Amazon EMR on EKS so that EMR Studio can communicate with your virtual cluster.</p>",
719                "smithy.api#http": {
720                    "method": "GET",
721                    "uri": "/virtualclusters/{virtualClusterId}/endpoints/{id}",
722                    "code": 200
723                }
724            }
725        },
726        "com.amazonaws.emrcontainers#DescribeManagedEndpointRequest": {
727            "type": "structure",
728            "members": {
729                "id": {
730                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
731                    "traits": {
732                        "smithy.api#documentation": "<p>This output displays ID of the managed endpoint.</p>",
733                        "smithy.api#httpLabel": {},
734                        "smithy.api#required": {}
735                    }
736                },
737                "virtualClusterId": {
738                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
739                    "traits": {
740                        "smithy.api#documentation": "<p>The ID of the endpoint's virtual cluster.</p>",
741                        "smithy.api#httpLabel": {},
742                        "smithy.api#required": {}
743                    }
744                }
745            }
746        },
747        "com.amazonaws.emrcontainers#DescribeManagedEndpointResponse": {
748            "type": "structure",
749            "members": {
750                "endpoint": {
751                    "target": "com.amazonaws.emrcontainers#Endpoint",
752                    "traits": {
753                        "smithy.api#documentation": "<p>This output displays information about a managed endpoint.</p>"
754                    }
755                }
756            }
757        },
758        "com.amazonaws.emrcontainers#DescribeVirtualCluster": {
759            "type": "operation",
760            "input": {
761                "target": "com.amazonaws.emrcontainers#DescribeVirtualClusterRequest"
762            },
763            "output": {
764                "target": "com.amazonaws.emrcontainers#DescribeVirtualClusterResponse"
765            },
766            "errors": [
767                {
768                    "target": "com.amazonaws.emrcontainers#InternalServerException"
769                },
770                {
771                    "target": "com.amazonaws.emrcontainers#ResourceNotFoundException"
772                },
773                {
774                    "target": "com.amazonaws.emrcontainers#ValidationException"
775                }
776            ],
777            "traits": {
778                "smithy.api#documentation": "<p>Displays detailed information about a specified virtual cluster. Virtual cluster is a managed entity on Amazon EMR on EKS. You can create, describe, list and delete virtual clusters. They do not consume any additional resource in your system. A single virtual cluster maps to a single Kubernetes namespace. Given this relationship, you can model virtual clusters the same way you model Kubernetes namespaces to meet your requirements.</p>",
779                "smithy.api#http": {
780                    "method": "GET",
781                    "uri": "/virtualclusters/{id}",
782                    "code": 200
783                }
784            }
785        },
786        "com.amazonaws.emrcontainers#DescribeVirtualClusterRequest": {
787            "type": "structure",
788            "members": {
789                "id": {
790                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
791                    "traits": {
792                        "smithy.api#documentation": "<p>The ID of the virtual cluster that will be described.</p>",
793                        "smithy.api#httpLabel": {},
794                        "smithy.api#required": {}
795                    }
796                }
797            }
798        },
799        "com.amazonaws.emrcontainers#DescribeVirtualClusterResponse": {
800            "type": "structure",
801            "members": {
802                "virtualCluster": {
803                    "target": "com.amazonaws.emrcontainers#VirtualCluster",
804                    "traits": {
805                        "smithy.api#documentation": "<p>This output displays information about the specified virtual cluster.</p>"
806                    }
807                }
808            }
809        },
810        "com.amazonaws.emrcontainers#EksInfo": {
811            "type": "structure",
812            "members": {
813                "namespace": {
814                    "target": "com.amazonaws.emrcontainers#String256",
815                    "traits": {
816                        "smithy.api#documentation": "<p>The namespaces of the EKS cluster.</p>"
817                    }
818                }
819            },
820            "traits": {
821                "smithy.api#documentation": "<p>The information about the EKS cluster.</p>"
822            }
823        },
824        "com.amazonaws.emrcontainers#Endpoint": {
825            "type": "structure",
826            "members": {
827                "id": {
828                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
829                    "traits": {
830                        "smithy.api#documentation": "<p>The ID of the endpoint.</p>"
831                    }
832                },
833                "name": {
834                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
835                    "traits": {
836                        "smithy.api#documentation": "<p>The name of the endpoint.</p>"
837                    }
838                },
839                "arn": {
840                    "target": "com.amazonaws.emrcontainers#EndpointArn",
841                    "traits": {
842                        "smithy.api#documentation": "<p>The ARN of the endpoint.</p>"
843                    }
844                },
845                "virtualClusterId": {
846                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
847                    "traits": {
848                        "smithy.api#documentation": "<p>The ID of the endpoint's virtual cluster.</p>"
849                    }
850                },
851                "type": {
852                    "target": "com.amazonaws.emrcontainers#EndpointType",
853                    "traits": {
854                        "smithy.api#documentation": "<p>The type of the endpoint.</p>"
855                    }
856                },
857                "state": {
858                    "target": "com.amazonaws.emrcontainers#EndpointState",
859                    "traits": {
860                        "smithy.api#documentation": "<p>The state of the endpoint.</p>"
861                    }
862                },
863                "releaseLabel": {
864                    "target": "com.amazonaws.emrcontainers#ReleaseLabel",
865                    "traits": {
866                        "smithy.api#documentation": "<p>The EMR release version to be used for the endpoint.</p>"
867                    }
868                },
869                "executionRoleArn": {
870                    "target": "com.amazonaws.emrcontainers#IAMRoleArn",
871                    "traits": {
872                        "smithy.api#documentation": "<p>The execution role ARN of the endpoint.</p>"
873                    }
874                },
875                "certificateArn": {
876                    "target": "com.amazonaws.emrcontainers#ACMCertArn",
877                    "traits": {
878                        "smithy.api#documentation": "<p>The certificate ARN of the endpoint.</p>"
879                    }
880                },
881                "configurationOverrides": {
882                    "target": "com.amazonaws.emrcontainers#ConfigurationOverrides",
883                    "traits": {
884                        "smithy.api#documentation": "<p>The configuration settings that are used to override existing configurations for endpoints.</p>"
885                    }
886                },
887                "serverUrl": {
888                    "target": "com.amazonaws.emrcontainers#UriString",
889                    "traits": {
890                        "smithy.api#documentation": "<p>The server URL of the endpoint.</p>"
891                    }
892                },
893                "createdAt": {
894                    "target": "com.amazonaws.emrcontainers#Date",
895                    "traits": {
896                        "smithy.api#documentation": "<p>The date and time when the endpoint was created.</p>"
897                    }
898                },
899                "securityGroup": {
900                    "target": "com.amazonaws.emrcontainers#String256",
901                    "traits": {
902                        "smithy.api#documentation": "<p>The security group configuration of the endpoint. \n      </p>"
903                    }
904                },
905                "subnetIds": {
906                    "target": "com.amazonaws.emrcontainers#SubnetIds",
907                    "traits": {
908                        "smithy.api#documentation": "<p>The subnet IDs of the endpoint.\n      </p>"
909                    }
910                },
911                "tags": {
912                    "target": "com.amazonaws.emrcontainers#TagMap",
913                    "traits": {
914                        "smithy.api#documentation": "<p>The tags of the endpoint. \n      </p>"
915                    }
916                }
917            },
918            "traits": {
919                "smithy.api#documentation": "<p>This entity represents the endpoint that is managed by Amazon EMR on EKS.</p>"
920            }
921        },
922        "com.amazonaws.emrcontainers#EndpointArn": {
923            "type": "string",
924            "traits": {
925                "smithy.api#length": {
926                    "min": 60,
927                    "max": 1024
928                },
929                "smithy.api#pattern": "^arn:(aws[a-zA-Z0-9-]*):emr-containers:.+:(\\d{12}):\\/virtualclusters\\/[0-9a-zA-Z]+\\/endpoints\\/[0-9a-zA-Z]+$"
930            }
931        },
932        "com.amazonaws.emrcontainers#EndpointState": {
933            "type": "string",
934            "traits": {
935                "smithy.api#enum": [
936                    {
937                        "value": "CREATING",
938                        "name": "CREATING"
939                    },
940                    {
941                        "value": "ACTIVE",
942                        "name": "ACTIVE"
943                    },
944                    {
945                        "value": "TERMINATING",
946                        "name": "TERMINATING"
947                    },
948                    {
949                        "value": "TERMINATED",
950                        "name": "TERMINATED"
951                    },
952                    {
953                        "value": "TERMINATED_WITH_ERRORS",
954                        "name": "TERMINATED_WITH_ERRORS"
955                    }
956                ]
957            }
958        },
959        "com.amazonaws.emrcontainers#EndpointStates": {
960            "type": "list",
961            "member": {
962                "target": "com.amazonaws.emrcontainers#EndpointState"
963            },
964            "traits": {
965                "smithy.api#length": {
966                    "min": 0,
967                    "max": 10
968                }
969            }
970        },
971        "com.amazonaws.emrcontainers#EndpointType": {
972            "type": "string",
973            "traits": {
974                "smithy.api#length": {
975                    "min": 1,
976                    "max": 64
977                },
978                "smithy.api#pattern": ".*\\S.*"
979            }
980        },
981        "com.amazonaws.emrcontainers#EndpointTypes": {
982            "type": "list",
983            "member": {
984                "target": "com.amazonaws.emrcontainers#EndpointType"
985            },
986            "traits": {
987                "smithy.api#length": {
988                    "min": 0,
989                    "max": 10
990                }
991            }
992        },
993        "com.amazonaws.emrcontainers#Endpoints": {
994            "type": "list",
995            "member": {
996                "target": "com.amazonaws.emrcontainers#Endpoint"
997            }
998        },
999        "com.amazonaws.emrcontainers#EntryPointArgument": {
1000            "type": "string",
1001            "traits": {
1002                "smithy.api#length": {
1003                    "min": 1,
1004                    "max": 10280
1005                },
1006                "smithy.api#pattern": "(?!\\s*$)(^[^';|\\u0026\\u003C\\u003E*?`$(){}\\[\\]!#\\\\]*$)",
1007                "smithy.api#sensitive": {}
1008            }
1009        },
1010        "com.amazonaws.emrcontainers#EntryPointArguments": {
1011            "type": "list",
1012            "member": {
1013                "target": "com.amazonaws.emrcontainers#EntryPointArgument"
1014            }
1015        },
1016        "com.amazonaws.emrcontainers#EntryPointPath": {
1017            "type": "string",
1018            "traits": {
1019                "smithy.api#length": {
1020                    "min": 1,
1021                    "max": 256
1022                },
1023                "smithy.api#pattern": "(?!\\s*$)(^[^';|\\u0026\\u003C\\u003E*?`$(){}\\[\\]!#\\\\]*$)",
1024                "smithy.api#sensitive": {}
1025            }
1026        },
1027        "com.amazonaws.emrcontainers#FailureReason": {
1028            "type": "string",
1029            "traits": {
1030                "smithy.api#enum": [
1031                    {
1032                        "value": "INTERNAL_ERROR",
1033                        "name": "INTERNAL_ERROR"
1034                    },
1035                    {
1036                        "value": "USER_ERROR",
1037                        "name": "USER_ERROR"
1038                    },
1039                    {
1040                        "value": "VALIDATION_ERROR",
1041                        "name": "VALIDATION_ERROR"
1042                    },
1043                    {
1044                        "value": "CLUSTER_UNAVAILABLE",
1045                        "name": "CLUSTER_UNAVAILABLE"
1046                    }
1047                ]
1048            }
1049        },
1050        "com.amazonaws.emrcontainers#IAMRoleArn": {
1051            "type": "string",
1052            "traits": {
1053                "smithy.api#length": {
1054                    "min": 20,
1055                    "max": 2048
1056                },
1057                "smithy.api#pattern": "^arn:(aws[a-zA-Z0-9-]*):iam::(\\d{12})?:(role((\\u002F)|(\\u002F[\\u0021-\\u007F]+\\u002F))[\\w+=,.@-]+)$"
1058            }
1059        },
1060        "com.amazonaws.emrcontainers#InternalServerException": {
1061            "type": "structure",
1062            "members": {
1063                "message": {
1064                    "target": "com.amazonaws.emrcontainers#String1024"
1065                }
1066            },
1067            "traits": {
1068                "smithy.api#documentation": "<p>This is an internal server exception.</p>",
1069                "smithy.api#error": "server",
1070                "smithy.api#httpError": 500
1071            }
1072        },
1073        "com.amazonaws.emrcontainers#JavaInteger": {
1074            "type": "integer",
1075            "traits": {
1076                "smithy.api#box": {}
1077            }
1078        },
1079        "com.amazonaws.emrcontainers#JobArn": {
1080            "type": "string",
1081            "traits": {
1082                "smithy.api#length": {
1083                    "min": 60,
1084                    "max": 1024
1085                },
1086                "smithy.api#pattern": "^arn:(aws[a-zA-Z0-9-]*):emr-containers:.+:(\\d{12}):\\/virtualclusters\\/[0-9a-zA-Z]+\\/jobruns\\/[0-9a-zA-Z]+$"
1087            }
1088        },
1089        "com.amazonaws.emrcontainers#JobDriver": {
1090            "type": "structure",
1091            "members": {
1092                "sparkSubmitJobDriver": {
1093                    "target": "com.amazonaws.emrcontainers#SparkSubmitJobDriver",
1094                    "traits": {
1095                        "smithy.api#documentation": "<p>The job driver parameters specified for spark submit.</p>"
1096                    }
1097                }
1098            },
1099            "traits": {
1100                "smithy.api#documentation": "<p>Specify the driver that the job runs on.</p>"
1101            }
1102        },
1103        "com.amazonaws.emrcontainers#JobRun": {
1104            "type": "structure",
1105            "members": {
1106                "id": {
1107                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
1108                    "traits": {
1109                        "smithy.api#documentation": "<p>The ID of the job run.</p>"
1110                    }
1111                },
1112                "name": {
1113                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
1114                    "traits": {
1115                        "smithy.api#documentation": "<p>The name of the job run.</p>"
1116                    }
1117                },
1118                "virtualClusterId": {
1119                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
1120                    "traits": {
1121                        "smithy.api#documentation": "<p>The ID of the job run's virtual cluster.</p>"
1122                    }
1123                },
1124                "arn": {
1125                    "target": "com.amazonaws.emrcontainers#JobArn",
1126                    "traits": {
1127                        "smithy.api#documentation": "<p>The ARN of job run.</p>"
1128                    }
1129                },
1130                "state": {
1131                    "target": "com.amazonaws.emrcontainers#JobRunState",
1132                    "traits": {
1133                        "smithy.api#documentation": "<p>The state of the job run. </p>"
1134                    }
1135                },
1136                "clientToken": {
1137                    "target": "com.amazonaws.emrcontainers#ClientToken",
1138                    "traits": {
1139                        "smithy.api#documentation": "<p>The client token used to start a job run.</p>"
1140                    }
1141                },
1142                "executionRoleArn": {
1143                    "target": "com.amazonaws.emrcontainers#IAMRoleArn",
1144                    "traits": {
1145                        "smithy.api#documentation": "<p>The execution role ARN of the job run.</p>"
1146                    }
1147                },
1148                "releaseLabel": {
1149                    "target": "com.amazonaws.emrcontainers#ReleaseLabel",
1150                    "traits": {
1151                        "smithy.api#documentation": "<p>The release version of Amazon EMR.</p>"
1152                    }
1153                },
1154                "configurationOverrides": {
1155                    "target": "com.amazonaws.emrcontainers#ConfigurationOverrides",
1156                    "traits": {
1157                        "smithy.api#documentation": "<p>The configuration settings that are used to override default configuration.</p>"
1158                    }
1159                },
1160                "jobDriver": {
1161                    "target": "com.amazonaws.emrcontainers#JobDriver",
1162                    "traits": {
1163                        "smithy.api#documentation": "<p>Parameters of job driver for the job run.</p>"
1164                    }
1165                },
1166                "createdAt": {
1167                    "target": "com.amazonaws.emrcontainers#Date",
1168                    "traits": {
1169                        "smithy.api#documentation": "<p>The date and time when the job run was created.</p>"
1170                    }
1171                },
1172                "createdBy": {
1173                    "target": "com.amazonaws.emrcontainers#RequestIdentityUserArn",
1174                    "traits": {
1175                        "smithy.api#documentation": "<p>The user who created the job run.</p>"
1176                    }
1177                },
1178                "finishedAt": {
1179                    "target": "com.amazonaws.emrcontainers#Date",
1180                    "traits": {
1181                        "smithy.api#documentation": "<p>The date and time when the job run has finished.</p>"
1182                    }
1183                },
1184                "stateDetails": {
1185                    "target": "com.amazonaws.emrcontainers#String256",
1186                    "traits": {
1187                        "smithy.api#documentation": "<p>Additional details of the job run state.</p>"
1188                    }
1189                },
1190                "failureReason": {
1191                    "target": "com.amazonaws.emrcontainers#FailureReason",
1192                    "traits": {
1193                        "smithy.api#documentation": "<p>The reasons why the job run has failed.</p>"
1194                    }
1195                },
1196                "tags": {
1197                    "target": "com.amazonaws.emrcontainers#TagMap",
1198                    "traits": {
1199                        "smithy.api#documentation": "<p>The assigned tags of the job run.</p>"
1200                    }
1201                }
1202            },
1203            "traits": {
1204                "smithy.api#documentation": "<p>This entity describes a job run. A job run is a unit of work, such as a Spark jar, PySpark script, or SparkSQL query, that you submit to Amazon EMR on EKS. </p>"
1205            }
1206        },
1207        "com.amazonaws.emrcontainers#JobRunState": {
1208            "type": "string",
1209            "traits": {
1210                "smithy.api#enum": [
1211                    {
1212                        "value": "PENDING",
1213                        "name": "PENDING"
1214                    },
1215                    {
1216                        "value": "SUBMITTED",
1217                        "name": "SUBMITTED"
1218                    },
1219                    {
1220                        "value": "RUNNING",
1221                        "name": "RUNNING"
1222                    },
1223                    {
1224                        "value": "FAILED",
1225                        "name": "FAILED"
1226                    },
1227                    {
1228                        "value": "CANCELLED",
1229                        "name": "CANCELLED"
1230                    },
1231                    {
1232                        "value": "CANCEL_PENDING",
1233                        "name": "CANCEL_PENDING"
1234                    },
1235                    {
1236                        "value": "COMPLETED",
1237                        "name": "COMPLETED"
1238                    }
1239                ]
1240            }
1241        },
1242        "com.amazonaws.emrcontainers#JobRunStates": {
1243            "type": "list",
1244            "member": {
1245                "target": "com.amazonaws.emrcontainers#JobRunState"
1246            },
1247            "traits": {
1248                "smithy.api#length": {
1249                    "min": 0,
1250                    "max": 10
1251                }
1252            }
1253        },
1254        "com.amazonaws.emrcontainers#JobRuns": {
1255            "type": "list",
1256            "member": {
1257                "target": "com.amazonaws.emrcontainers#JobRun"
1258            }
1259        },
1260        "com.amazonaws.emrcontainers#ListJobRuns": {
1261            "type": "operation",
1262            "input": {
1263                "target": "com.amazonaws.emrcontainers#ListJobRunsRequest"
1264            },
1265            "output": {
1266                "target": "com.amazonaws.emrcontainers#ListJobRunsResponse"
1267            },
1268            "errors": [
1269                {
1270                    "target": "com.amazonaws.emrcontainers#InternalServerException"
1271                },
1272                {
1273                    "target": "com.amazonaws.emrcontainers#ValidationException"
1274                }
1275            ],
1276            "traits": {
1277                "smithy.api#documentation": "<p>Lists job runs based on a set of parameters. A job run is a unit of work, such as a Spark jar, PySpark script, or SparkSQL query, that you submit to Amazon EMR on EKS.</p>",
1278                "smithy.api#http": {
1279                    "method": "GET",
1280                    "uri": "/virtualclusters/{virtualClusterId}/jobruns",
1281                    "code": 200
1282                },
1283                "smithy.api#paginated": {
1284                    "inputToken": "nextToken",
1285                    "outputToken": "nextToken",
1286                    "pageSize": "maxResults"
1287                }
1288            }
1289        },
1290        "com.amazonaws.emrcontainers#ListJobRunsRequest": {
1291            "type": "structure",
1292            "members": {
1293                "virtualClusterId": {
1294                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
1295                    "traits": {
1296                        "smithy.api#documentation": "<p>The ID of the virtual cluster for which to list the job run. </p>",
1297                        "smithy.api#httpLabel": {},
1298                        "smithy.api#required": {}
1299                    }
1300                },
1301                "createdBefore": {
1302                    "target": "com.amazonaws.emrcontainers#Date",
1303                    "traits": {
1304                        "smithy.api#documentation": "<p>The date and time before which the job runs were submitted.</p>",
1305                        "smithy.api#httpQuery": "createdBefore"
1306                    }
1307                },
1308                "createdAfter": {
1309                    "target": "com.amazonaws.emrcontainers#Date",
1310                    "traits": {
1311                        "smithy.api#documentation": "<p>The date and time after which the job runs were submitted.</p>",
1312                        "smithy.api#httpQuery": "createdAfter"
1313                    }
1314                },
1315                "name": {
1316                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
1317                    "traits": {
1318                        "smithy.api#documentation": "<p>The name of the job run.</p>",
1319                        "smithy.api#httpQuery": "name"
1320                    }
1321                },
1322                "states": {
1323                    "target": "com.amazonaws.emrcontainers#JobRunStates",
1324                    "traits": {
1325                        "smithy.api#documentation": "<p>The states of the job run.</p>",
1326                        "smithy.api#httpQuery": "states"
1327                    }
1328                },
1329                "maxResults": {
1330                    "target": "com.amazonaws.emrcontainers#JavaInteger",
1331                    "traits": {
1332                        "smithy.api#documentation": "<p>The maximum number of job runs that can be listed.</p>",
1333                        "smithy.api#httpQuery": "maxResults"
1334                    }
1335                },
1336                "nextToken": {
1337                    "target": "com.amazonaws.emrcontainers#NextToken",
1338                    "traits": {
1339                        "smithy.api#documentation": "<p>The token for the next set of job runs to return.</p>",
1340                        "smithy.api#httpQuery": "nextToken"
1341                    }
1342                }
1343            }
1344        },
1345        "com.amazonaws.emrcontainers#ListJobRunsResponse": {
1346            "type": "structure",
1347            "members": {
1348                "jobRuns": {
1349                    "target": "com.amazonaws.emrcontainers#JobRuns",
1350                    "traits": {
1351                        "smithy.api#documentation": "<p>This output lists information about the specified job runs.</p>"
1352                    }
1353                },
1354                "nextToken": {
1355                    "target": "com.amazonaws.emrcontainers#NextToken",
1356                    "traits": {
1357                        "smithy.api#documentation": "<p>This output displays the token for the next set of job runs.</p>"
1358                    }
1359                }
1360            }
1361        },
1362        "com.amazonaws.emrcontainers#ListManagedEndpoints": {
1363            "type": "operation",
1364            "input": {
1365                "target": "com.amazonaws.emrcontainers#ListManagedEndpointsRequest"
1366            },
1367            "output": {
1368                "target": "com.amazonaws.emrcontainers#ListManagedEndpointsResponse"
1369            },
1370            "errors": [
1371                {
1372                    "target": "com.amazonaws.emrcontainers#InternalServerException"
1373                },
1374                {
1375                    "target": "com.amazonaws.emrcontainers#ValidationException"
1376                }
1377            ],
1378            "traits": {
1379                "smithy.api#documentation": "<p>Lists managed endpoints based on a set of parameters. A managed endpoint is a gateway that connects EMR Studio to Amazon EMR on EKS so that EMR Studio can communicate with your virtual cluster.</p>",
1380                "smithy.api#http": {
1381                    "method": "GET",
1382                    "uri": "/virtualclusters/{virtualClusterId}/endpoints",
1383                    "code": 200
1384                },
1385                "smithy.api#paginated": {
1386                    "inputToken": "nextToken",
1387                    "outputToken": "nextToken",
1388                    "pageSize": "maxResults"
1389                }
1390            }
1391        },
1392        "com.amazonaws.emrcontainers#ListManagedEndpointsRequest": {
1393            "type": "structure",
1394            "members": {
1395                "virtualClusterId": {
1396                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
1397                    "traits": {
1398                        "smithy.api#documentation": "<p>The ID of the virtual cluster.</p>",
1399                        "smithy.api#httpLabel": {},
1400                        "smithy.api#required": {}
1401                    }
1402                },
1403                "createdBefore": {
1404                    "target": "com.amazonaws.emrcontainers#Date",
1405                    "traits": {
1406                        "smithy.api#documentation": "<p>The date and time before which the endpoints are created.</p>",
1407                        "smithy.api#httpQuery": "createdBefore"
1408                    }
1409                },
1410                "createdAfter": {
1411                    "target": "com.amazonaws.emrcontainers#Date",
1412                    "traits": {
1413                        "smithy.api#documentation": "<p> The date and time after which the endpoints are created.</p>",
1414                        "smithy.api#httpQuery": "createdAfter"
1415                    }
1416                },
1417                "types": {
1418                    "target": "com.amazonaws.emrcontainers#EndpointTypes",
1419                    "traits": {
1420                        "smithy.api#documentation": "<p>The types of the managed endpoints.</p>",
1421                        "smithy.api#httpQuery": "types"
1422                    }
1423                },
1424                "states": {
1425                    "target": "com.amazonaws.emrcontainers#EndpointStates",
1426                    "traits": {
1427                        "smithy.api#documentation": "<p>The states of the managed endpoints.</p>",
1428                        "smithy.api#httpQuery": "states"
1429                    }
1430                },
1431                "maxResults": {
1432                    "target": "com.amazonaws.emrcontainers#JavaInteger",
1433                    "traits": {
1434                        "smithy.api#documentation": "<p>The maximum number of managed endpoints that can be listed.</p>",
1435                        "smithy.api#httpQuery": "maxResults"
1436                    }
1437                },
1438                "nextToken": {
1439                    "target": "com.amazonaws.emrcontainers#NextToken",
1440                    "traits": {
1441                        "smithy.api#documentation": "<p> The token for the next set of managed endpoints to return. </p>",
1442                        "smithy.api#httpQuery": "nextToken"
1443                    }
1444                }
1445            }
1446        },
1447        "com.amazonaws.emrcontainers#ListManagedEndpointsResponse": {
1448            "type": "structure",
1449            "members": {
1450                "endpoints": {
1451                    "target": "com.amazonaws.emrcontainers#Endpoints",
1452                    "traits": {
1453                        "smithy.api#documentation": "<p>The managed endpoints to be listed.</p>"
1454                    }
1455                },
1456                "nextToken": {
1457                    "target": "com.amazonaws.emrcontainers#NextToken",
1458                    "traits": {
1459                        "smithy.api#documentation": "<p> The token for the next set of endpoints to return. </p>"
1460                    }
1461                }
1462            }
1463        },
1464        "com.amazonaws.emrcontainers#ListTagsForResource": {
1465            "type": "operation",
1466            "input": {
1467                "target": "com.amazonaws.emrcontainers#ListTagsForResourceRequest"
1468            },
1469            "output": {
1470                "target": "com.amazonaws.emrcontainers#ListTagsForResourceResponse"
1471            },
1472            "errors": [
1473                {
1474                    "target": "com.amazonaws.emrcontainers#InternalServerException"
1475                },
1476                {
1477                    "target": "com.amazonaws.emrcontainers#ResourceNotFoundException"
1478                },
1479                {
1480                    "target": "com.amazonaws.emrcontainers#ValidationException"
1481                }
1482            ],
1483            "traits": {
1484                "smithy.api#documentation": "<p>Lists the tags assigned to the resources.</p>",
1485                "smithy.api#http": {
1486                    "method": "GET",
1487                    "uri": "/tags/{resourceArn}",
1488                    "code": 200
1489                }
1490            }
1491        },
1492        "com.amazonaws.emrcontainers#ListTagsForResourceRequest": {
1493            "type": "structure",
1494            "members": {
1495                "resourceArn": {
1496                    "target": "com.amazonaws.emrcontainers#RsiArn",
1497                    "traits": {
1498                        "smithy.api#documentation": "<p>The ARN of tagged resources.</p>",
1499                        "smithy.api#httpLabel": {},
1500                        "smithy.api#required": {}
1501                    }
1502                }
1503            }
1504        },
1505        "com.amazonaws.emrcontainers#ListTagsForResourceResponse": {
1506            "type": "structure",
1507            "members": {
1508                "tags": {
1509                    "target": "com.amazonaws.emrcontainers#TagMap",
1510                    "traits": {
1511                        "smithy.api#documentation": "<p>The tags assigned to resources.</p>"
1512                    }
1513                }
1514            }
1515        },
1516        "com.amazonaws.emrcontainers#ListVirtualClusters": {
1517            "type": "operation",
1518            "input": {
1519                "target": "com.amazonaws.emrcontainers#ListVirtualClustersRequest"
1520            },
1521            "output": {
1522                "target": "com.amazonaws.emrcontainers#ListVirtualClustersResponse"
1523            },
1524            "errors": [
1525                {
1526                    "target": "com.amazonaws.emrcontainers#InternalServerException"
1527                },
1528                {
1529                    "target": "com.amazonaws.emrcontainers#ValidationException"
1530                }
1531            ],
1532            "traits": {
1533                "smithy.api#documentation": "<p>Lists information about the specified virtual cluster. Virtual cluster is a managed entity on Amazon EMR on EKS. You can create, describe, list and delete virtual clusters. They do not consume any additional resource in your system. A single virtual cluster maps to a single Kubernetes namespace. Given this relationship, you can model virtual clusters the same way you model Kubernetes namespaces to meet your requirements.</p>",
1534                "smithy.api#http": {
1535                    "method": "GET",
1536                    "uri": "/virtualclusters",
1537                    "code": 200
1538                },
1539                "smithy.api#paginated": {
1540                    "inputToken": "nextToken",
1541                    "outputToken": "nextToken",
1542                    "pageSize": "maxResults"
1543                }
1544            }
1545        },
1546        "com.amazonaws.emrcontainers#ListVirtualClustersRequest": {
1547            "type": "structure",
1548            "members": {
1549                "containerProviderId": {
1550                    "target": "com.amazonaws.emrcontainers#String1024",
1551                    "traits": {
1552                        "smithy.api#documentation": "<p>The container provider ID of the virtual cluster.</p>",
1553                        "smithy.api#httpQuery": "containerProviderId"
1554                    }
1555                },
1556                "containerProviderType": {
1557                    "target": "com.amazonaws.emrcontainers#ContainerProviderType",
1558                    "traits": {
1559                        "smithy.api#documentation": "<p>The container provider type of the virtual cluster. EKS is the only supported type as of now.</p>",
1560                        "smithy.api#httpQuery": "containerProviderType"
1561                    }
1562                },
1563                "createdAfter": {
1564                    "target": "com.amazonaws.emrcontainers#Date",
1565                    "traits": {
1566                        "smithy.api#documentation": "<p>The date and time after which the virtual clusters are created.</p>",
1567                        "smithy.api#httpQuery": "createdAfter"
1568                    }
1569                },
1570                "createdBefore": {
1571                    "target": "com.amazonaws.emrcontainers#Date",
1572                    "traits": {
1573                        "smithy.api#documentation": "<p>The date and time before which the virtual clusters are created.</p>",
1574                        "smithy.api#httpQuery": "createdBefore"
1575                    }
1576                },
1577                "states": {
1578                    "target": "com.amazonaws.emrcontainers#VirtualClusterStates",
1579                    "traits": {
1580                        "smithy.api#documentation": "<p>The states of the requested virtual clusters.</p>",
1581                        "smithy.api#httpQuery": "states"
1582                    }
1583                },
1584                "maxResults": {
1585                    "target": "com.amazonaws.emrcontainers#JavaInteger",
1586                    "traits": {
1587                        "smithy.api#documentation": "<p>The maximum number of virtual clusters that can be listed.</p>",
1588                        "smithy.api#httpQuery": "maxResults"
1589                    }
1590                },
1591                "nextToken": {
1592                    "target": "com.amazonaws.emrcontainers#NextToken",
1593                    "traits": {
1594                        "smithy.api#documentation": "<p>The token for the next set of virtual clusters to return. </p>",
1595                        "smithy.api#httpQuery": "nextToken"
1596                    }
1597                }
1598            }
1599        },
1600        "com.amazonaws.emrcontainers#ListVirtualClustersResponse": {
1601            "type": "structure",
1602            "members": {
1603                "virtualClusters": {
1604                    "target": "com.amazonaws.emrcontainers#VirtualClusters",
1605                    "traits": {
1606                        "smithy.api#documentation": "<p>This output lists the specified virtual clusters.</p>"
1607                    }
1608                },
1609                "nextToken": {
1610                    "target": "com.amazonaws.emrcontainers#NextToken",
1611                    "traits": {
1612                        "smithy.api#documentation": "<p>This output displays the token for the next set of virtual clusters.</p>"
1613                    }
1614                }
1615            }
1616        },
1617        "com.amazonaws.emrcontainers#LogGroupName": {
1618            "type": "string",
1619            "traits": {
1620                "smithy.api#length": {
1621                    "min": 1,
1622                    "max": 512
1623                },
1624                "smithy.api#pattern": "[\\.\\-_/#A-Za-z0-9]+"
1625            }
1626        },
1627        "com.amazonaws.emrcontainers#MonitoringConfiguration": {
1628            "type": "structure",
1629            "members": {
1630                "persistentAppUI": {
1631                    "target": "com.amazonaws.emrcontainers#PersistentAppUI",
1632                    "traits": {
1633                        "smithy.api#documentation": "<p>Monitoring configurations for the persistent application UI. </p>"
1634                    }
1635                },
1636                "cloudWatchMonitoringConfiguration": {
1637                    "target": "com.amazonaws.emrcontainers#CloudWatchMonitoringConfiguration",
1638                    "traits": {
1639                        "smithy.api#documentation": "<p>Monitoring configurations for CloudWatch.</p>"
1640                    }
1641                },
1642                "s3MonitoringConfiguration": {
1643                    "target": "com.amazonaws.emrcontainers#S3MonitoringConfiguration",
1644                    "traits": {
1645                        "smithy.api#documentation": "<p>Amazon S3 configuration for monitoring log publishing.</p>"
1646                    }
1647                }
1648            },
1649            "traits": {
1650                "smithy.api#documentation": "<p>Configuration setting for monitoring.</p>"
1651            }
1652        },
1653        "com.amazonaws.emrcontainers#NextToken": {
1654            "type": "string",
1655            "traits": {
1656                "smithy.api#length": {
1657                    "min": 1,
1658                    "max": 1024
1659                },
1660                "smithy.api#pattern": ".*\\S.*"
1661            }
1662        },
1663        "com.amazonaws.emrcontainers#PersistentAppUI": {
1664            "type": "string",
1665            "traits": {
1666                "smithy.api#enum": [
1667                    {
1668                        "value": "ENABLED",
1669                        "name": "ENABLED"
1670                    },
1671                    {
1672                        "value": "DISABLED",
1673                        "name": "DISABLED"
1674                    }
1675                ]
1676            }
1677        },
1678        "com.amazonaws.emrcontainers#ReleaseLabel": {
1679            "type": "string",
1680            "traits": {
1681                "smithy.api#length": {
1682                    "min": 1,
1683                    "max": 64
1684                },
1685                "smithy.api#pattern": "[\\.\\-_/A-Za-z0-9]+"
1686            }
1687        },
1688        "com.amazonaws.emrcontainers#RequestIdentityUserArn": {
1689            "type": "string",
1690            "traits": {
1691                "smithy.api#length": {
1692                    "min": 20,
1693                    "max": 2048
1694                },
1695                "smithy.api#pattern": "^arn:(aws[a-zA-Z0-9-]*):(iam|sts)::(\\d{12})?:[\\w/+=,.@-]+$"
1696            }
1697        },
1698        "com.amazonaws.emrcontainers#ResourceIdString": {
1699            "type": "string",
1700            "traits": {
1701                "smithy.api#length": {
1702                    "min": 1,
1703                    "max": 64
1704                },
1705                "smithy.api#pattern": "[0-9a-z]+"
1706            }
1707        },
1708        "com.amazonaws.emrcontainers#ResourceNameString": {
1709            "type": "string",
1710            "traits": {
1711                "smithy.api#length": {
1712                    "min": 1,
1713                    "max": 64
1714                },
1715                "smithy.api#pattern": "[\\.\\-_/#A-Za-z0-9]+"
1716            }
1717        },
1718        "com.amazonaws.emrcontainers#ResourceNotFoundException": {
1719            "type": "structure",
1720            "members": {
1721                "message": {
1722                    "target": "com.amazonaws.emrcontainers#String1024"
1723                }
1724            },
1725            "traits": {
1726                "smithy.api#documentation": "<p>The specified resource was not found.</p>",
1727                "smithy.api#error": "client",
1728                "smithy.api#httpError": 400
1729            }
1730        },
1731        "com.amazonaws.emrcontainers#RsiArn": {
1732            "type": "string",
1733            "traits": {
1734                "smithy.api#length": {
1735                    "min": 60,
1736                    "max": 500
1737                },
1738                "smithy.api#pattern": "^arn:(aws[a-zA-Z0-9-]*):emr-containers:.+:(\\d{12}):/virtualclusters/.+$"
1739            }
1740        },
1741        "com.amazonaws.emrcontainers#S3MonitoringConfiguration": {
1742            "type": "structure",
1743            "members": {
1744                "logUri": {
1745                    "target": "com.amazonaws.emrcontainers#UriString",
1746                    "traits": {
1747                        "smithy.api#documentation": "<p>Amazon S3 destination URI for log publishing.</p>",
1748                        "smithy.api#required": {}
1749                    }
1750                }
1751            },
1752            "traits": {
1753                "smithy.api#documentation": "<p> Amazon S3 configuration for monitoring log publishing. You can configure your jobs to send log information to Amazon S3.</p>"
1754            }
1755        },
1756        "com.amazonaws.emrcontainers#SensitivePropertiesMap": {
1757            "type": "map",
1758            "key": {
1759                "target": "com.amazonaws.emrcontainers#String1024"
1760            },
1761            "value": {
1762                "target": "com.amazonaws.emrcontainers#String1024"
1763            },
1764            "traits": {
1765                "smithy.api#length": {
1766                    "min": 0,
1767                    "max": 100
1768                },
1769                "smithy.api#sensitive": {}
1770            }
1771        },
1772        "com.amazonaws.emrcontainers#SparkSubmitJobDriver": {
1773            "type": "structure",
1774            "members": {
1775                "entryPoint": {
1776                    "target": "com.amazonaws.emrcontainers#EntryPointPath",
1777                    "traits": {
1778                        "smithy.api#documentation": "<p>The entry point of job application.</p>",
1779                        "smithy.api#required": {}
1780                    }
1781                },
1782                "entryPointArguments": {
1783                    "target": "com.amazonaws.emrcontainers#EntryPointArguments",
1784                    "traits": {
1785                        "smithy.api#documentation": "<p>The arguments for job application.</p>"
1786                    }
1787                },
1788                "sparkSubmitParameters": {
1789                    "target": "com.amazonaws.emrcontainers#SparkSubmitParameters",
1790                    "traits": {
1791                        "smithy.api#documentation": "<p>The Spark submit parameters that are used for job runs.</p>"
1792                    }
1793                }
1794            },
1795            "traits": {
1796                "smithy.api#documentation": "<p>The information about job driver for Spark submit.</p>"
1797            }
1798        },
1799        "com.amazonaws.emrcontainers#SparkSubmitParameters": {
1800            "type": "string",
1801            "traits": {
1802                "smithy.api#length": {
1803                    "min": 1,
1804                    "max": 1024
1805                },
1806                "smithy.api#pattern": "(?!\\s*$)(^[^';|\\u0026\\u003C\\u003E*?`$(){}\\[\\]!#\\\\]*$)",
1807                "smithy.api#sensitive": {}
1808            }
1809        },
1810        "com.amazonaws.emrcontainers#StartJobRun": {
1811            "type": "operation",
1812            "input": {
1813                "target": "com.amazonaws.emrcontainers#StartJobRunRequest"
1814            },
1815            "output": {
1816                "target": "com.amazonaws.emrcontainers#StartJobRunResponse"
1817            },
1818            "errors": [
1819                {
1820                    "target": "com.amazonaws.emrcontainers#InternalServerException"
1821                },
1822                {
1823                    "target": "com.amazonaws.emrcontainers#ResourceNotFoundException"
1824                },
1825                {
1826                    "target": "com.amazonaws.emrcontainers#ValidationException"
1827                }
1828            ],
1829            "traits": {
1830                "smithy.api#documentation": "<p>Starts a job run. A job run is a unit of work, such as a Spark jar, PySpark script, or SparkSQL query, that you submit to Amazon EMR on EKS.</p>",
1831                "smithy.api#http": {
1832                    "method": "POST",
1833                    "uri": "/virtualclusters/{virtualClusterId}/jobruns",
1834                    "code": 200
1835                }
1836            }
1837        },
1838        "com.amazonaws.emrcontainers#StartJobRunRequest": {
1839            "type": "structure",
1840            "members": {
1841                "name": {
1842                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
1843                    "traits": {
1844                        "smithy.api#documentation": "<p>The name of the job run.</p>"
1845                    }
1846                },
1847                "virtualClusterId": {
1848                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
1849                    "traits": {
1850                        "smithy.api#documentation": "<p>The virtual cluster ID for which the job run request is submitted.</p>",
1851                        "smithy.api#httpLabel": {},
1852                        "smithy.api#required": {}
1853                    }
1854                },
1855                "clientToken": {
1856                    "target": "com.amazonaws.emrcontainers#ClientToken",
1857                    "traits": {
1858                        "smithy.api#documentation": "<p>The client idempotency token of the job run request. </p>",
1859                        "smithy.api#idempotencyToken": {},
1860                        "smithy.api#required": {}
1861                    }
1862                },
1863                "executionRoleArn": {
1864                    "target": "com.amazonaws.emrcontainers#IAMRoleArn",
1865                    "traits": {
1866                        "smithy.api#documentation": "<p>The execution role ARN for the job run.</p>",
1867                        "smithy.api#required": {}
1868                    }
1869                },
1870                "releaseLabel": {
1871                    "target": "com.amazonaws.emrcontainers#ReleaseLabel",
1872                    "traits": {
1873                        "smithy.api#documentation": "<p>The Amazon EMR release version to use for the job run.</p>",
1874                        "smithy.api#required": {}
1875                    }
1876                },
1877                "jobDriver": {
1878                    "target": "com.amazonaws.emrcontainers#JobDriver",
1879                    "traits": {
1880                        "smithy.api#documentation": "<p>The job driver for the job run.</p>",
1881                        "smithy.api#required": {}
1882                    }
1883                },
1884                "configurationOverrides": {
1885                    "target": "com.amazonaws.emrcontainers#ConfigurationOverrides",
1886                    "traits": {
1887                        "smithy.api#documentation": "<p>The configuration overrides for the job run.</p>"
1888                    }
1889                },
1890                "tags": {
1891                    "target": "com.amazonaws.emrcontainers#TagMap",
1892                    "traits": {
1893                        "smithy.api#documentation": "<p>The tags assigned to job runs.</p>"
1894                    }
1895                }
1896            }
1897        },
1898        "com.amazonaws.emrcontainers#StartJobRunResponse": {
1899            "type": "structure",
1900            "members": {
1901                "id": {
1902                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
1903                    "traits": {
1904                        "smithy.api#documentation": "<p>This output displays the started job run ID.</p>"
1905                    }
1906                },
1907                "name": {
1908                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
1909                    "traits": {
1910                        "smithy.api#documentation": "<p>This output displays the name of the started job run.</p>"
1911                    }
1912                },
1913                "arn": {
1914                    "target": "com.amazonaws.emrcontainers#JobArn",
1915                    "traits": {
1916                        "smithy.api#documentation": "<p>This output lists the ARN of job run.</p>"
1917                    }
1918                },
1919                "virtualClusterId": {
1920                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
1921                    "traits": {
1922                        "smithy.api#documentation": "<p>This output displays the virtual cluster ID for which the job run was submitted.</p>"
1923                    }
1924                }
1925            }
1926        },
1927        "com.amazonaws.emrcontainers#String1024": {
1928            "type": "string",
1929            "traits": {
1930                "smithy.api#length": {
1931                    "min": 1,
1932                    "max": 1024
1933                },
1934                "smithy.api#pattern": ".*\\S.*"
1935            }
1936        },
1937        "com.amazonaws.emrcontainers#String128": {
1938            "type": "string",
1939            "traits": {
1940                "smithy.api#length": {
1941                    "min": 1,
1942                    "max": 128
1943                },
1944                "smithy.api#pattern": ".*\\S.*"
1945            }
1946        },
1947        "com.amazonaws.emrcontainers#String256": {
1948            "type": "string",
1949            "traits": {
1950                "smithy.api#length": {
1951                    "min": 1,
1952                    "max": 256
1953                },
1954                "smithy.api#pattern": ".*\\S.*"
1955            }
1956        },
1957        "com.amazonaws.emrcontainers#StringEmpty256": {
1958            "type": "string",
1959            "traits": {
1960                "smithy.api#length": {
1961                    "min": 0,
1962                    "max": 256
1963                },
1964                "smithy.api#pattern": ".*\\S.*"
1965            }
1966        },
1967        "com.amazonaws.emrcontainers#SubnetIds": {
1968            "type": "list",
1969            "member": {
1970                "target": "com.amazonaws.emrcontainers#String256"
1971            }
1972        },
1973        "com.amazonaws.emrcontainers#TagKeyList": {
1974            "type": "list",
1975            "member": {
1976                "target": "com.amazonaws.emrcontainers#String128"
1977            },
1978            "traits": {
1979                "smithy.api#length": {
1980                    "min": 0,
1981                    "max": 50
1982                }
1983            }
1984        },
1985        "com.amazonaws.emrcontainers#TagMap": {
1986            "type": "map",
1987            "key": {
1988                "target": "com.amazonaws.emrcontainers#String128"
1989            },
1990            "value": {
1991                "target": "com.amazonaws.emrcontainers#StringEmpty256"
1992            },
1993            "traits": {
1994                "smithy.api#length": {
1995                    "min": 0,
1996                    "max": 50
1997                }
1998            }
1999        },
2000        "com.amazonaws.emrcontainers#TagResource": {
2001            "type": "operation",
2002            "input": {
2003                "target": "com.amazonaws.emrcontainers#TagResourceRequest"
2004            },
2005            "output": {
2006                "target": "com.amazonaws.emrcontainers#TagResourceResponse"
2007            },
2008            "errors": [
2009                {
2010                    "target": "com.amazonaws.emrcontainers#InternalServerException"
2011                },
2012                {
2013                    "target": "com.amazonaws.emrcontainers#ResourceNotFoundException"
2014                },
2015                {
2016                    "target": "com.amazonaws.emrcontainers#ValidationException"
2017                }
2018            ],
2019            "traits": {
2020                "smithy.api#documentation": "<p>Assigns tags to resources. A tag is a label that you assign to an AWS resource. Each tag consists of a key and an optional value, both of which you define. Tags enable you to categorize your AWS resources by attributes such as purpose, owner, or environment. When you have many resources of the same type, you can quickly identify a specific resource based on the tags you've assigned to it. For example, you can define a set of tags for your Amazon EMR on EKS clusters to help you track each cluster's owner and stack level. We recommend that you devise a consistent set of tag keys for each resource type. You can then search and filter the resources based on the tags that you add.</p>",
2021                "smithy.api#http": {
2022                    "method": "POST",
2023                    "uri": "/tags/{resourceArn}",
2024                    "code": 200
2025                }
2026            }
2027        },
2028        "com.amazonaws.emrcontainers#TagResourceRequest": {
2029            "type": "structure",
2030            "members": {
2031                "resourceArn": {
2032                    "target": "com.amazonaws.emrcontainers#RsiArn",
2033                    "traits": {
2034                        "smithy.api#documentation": "<p>The ARN of resources.</p>",
2035                        "smithy.api#httpLabel": {},
2036                        "smithy.api#required": {}
2037                    }
2038                },
2039                "tags": {
2040                    "target": "com.amazonaws.emrcontainers#TagMap",
2041                    "traits": {
2042                        "smithy.api#documentation": "<p>The tags assigned to resources.</p>",
2043                        "smithy.api#required": {}
2044                    }
2045                }
2046            }
2047        },
2048        "com.amazonaws.emrcontainers#TagResourceResponse": {
2049            "type": "structure",
2050            "members": {}
2051        },
2052        "com.amazonaws.emrcontainers#UntagResource": {
2053            "type": "operation",
2054            "input": {
2055                "target": "com.amazonaws.emrcontainers#UntagResourceRequest"
2056            },
2057            "output": {
2058                "target": "com.amazonaws.emrcontainers#UntagResourceResponse"
2059            },
2060            "errors": [
2061                {
2062                    "target": "com.amazonaws.emrcontainers#InternalServerException"
2063                },
2064                {
2065                    "target": "com.amazonaws.emrcontainers#ResourceNotFoundException"
2066                },
2067                {
2068                    "target": "com.amazonaws.emrcontainers#ValidationException"
2069                }
2070            ],
2071            "traits": {
2072                "smithy.api#documentation": "<p>Removes tags from resources.</p>",
2073                "smithy.api#http": {
2074                    "method": "DELETE",
2075                    "uri": "/tags/{resourceArn}",
2076                    "code": 200
2077                }
2078            }
2079        },
2080        "com.amazonaws.emrcontainers#UntagResourceRequest": {
2081            "type": "structure",
2082            "members": {
2083                "resourceArn": {
2084                    "target": "com.amazonaws.emrcontainers#RsiArn",
2085                    "traits": {
2086                        "smithy.api#documentation": "<p>The ARN of resources.</p>",
2087                        "smithy.api#httpLabel": {},
2088                        "smithy.api#required": {}
2089                    }
2090                },
2091                "tagKeys": {
2092                    "target": "com.amazonaws.emrcontainers#TagKeyList",
2093                    "traits": {
2094                        "smithy.api#documentation": "<p>The tag keys of the resources.</p>",
2095                        "smithy.api#httpQuery": "tagKeys",
2096                        "smithy.api#required": {}
2097                    }
2098                }
2099            }
2100        },
2101        "com.amazonaws.emrcontainers#UntagResourceResponse": {
2102            "type": "structure",
2103            "members": {}
2104        },
2105        "com.amazonaws.emrcontainers#UriString": {
2106            "type": "string",
2107            "traits": {
2108                "smithy.api#length": {
2109                    "min": 1,
2110                    "max": 10280
2111                },
2112                "smithy.api#pattern": "[\\u0020-\\uD7FF\\uE000-\\uFFFD\\uD800\\uDBFF-\\uDC00\\uDFFF\\r\\n\\t]*"
2113            }
2114        },
2115        "com.amazonaws.emrcontainers#ValidationException": {
2116            "type": "structure",
2117            "members": {
2118                "message": {
2119                    "target": "com.amazonaws.emrcontainers#String1024"
2120                }
2121            },
2122            "traits": {
2123                "smithy.api#documentation": "<p>There are invalid parameters in the client request.</p>",
2124                "smithy.api#error": "client",
2125                "smithy.api#httpError": 400
2126            }
2127        },
2128        "com.amazonaws.emrcontainers#VirtualCluster": {
2129            "type": "structure",
2130            "members": {
2131                "id": {
2132                    "target": "com.amazonaws.emrcontainers#ResourceIdString",
2133                    "traits": {
2134                        "smithy.api#documentation": "<p>The ID of the virtual cluster.</p>"
2135                    }
2136                },
2137                "name": {
2138                    "target": "com.amazonaws.emrcontainers#ResourceNameString",
2139                    "traits": {
2140                        "smithy.api#documentation": "<p>The name of the virtual cluster.</p>"
2141                    }
2142                },
2143                "arn": {
2144                    "target": "com.amazonaws.emrcontainers#VirtualClusterArn",
2145                    "traits": {
2146                        "smithy.api#documentation": "<p>The ARN of the virtual cluster.</p>"
2147                    }
2148                },
2149                "state": {
2150                    "target": "com.amazonaws.emrcontainers#VirtualClusterState",
2151                    "traits": {
2152                        "smithy.api#documentation": "<p>The state of the virtual cluster.</p>"
2153                    }
2154                },
2155                "containerProvider": {
2156                    "target": "com.amazonaws.emrcontainers#ContainerProvider",
2157                    "traits": {
2158                        "smithy.api#documentation": "<p>The container provider of the virtual cluster.</p>"
2159                    }
2160                },
2161                "createdAt": {
2162                    "target": "com.amazonaws.emrcontainers#Date",
2163                    "traits": {
2164                        "smithy.api#documentation": "<p>The date and time when the virtual cluster is created.</p>"
2165                    }
2166                },
2167                "tags": {
2168                    "target": "com.amazonaws.emrcontainers#TagMap",
2169                    "traits": {
2170                        "smithy.api#documentation": "<p>The assigned tags of the virtual cluster.</p>"
2171                    }
2172                }
2173            },
2174            "traits": {
2175                "smithy.api#documentation": "<p>This entity describes a virtual cluster. A virtual cluster is a Kubernetes namespace that Amazon EMR is registered with. Amazon EMR uses virtual clusters to run jobs and host endpoints. Multiple virtual clusters can be backed by the same physical cluster. However, each virtual cluster maps to one namespace on an EKS cluster. Virtual clusters do not create any active resources that contribute to your bill or that require lifecycle management outside the service.</p>"
2176            }
2177        },
2178        "com.amazonaws.emrcontainers#VirtualClusterArn": {
2179            "type": "string",
2180            "traits": {
2181                "smithy.api#length": {
2182                    "min": 60,
2183                    "max": 1024
2184                },
2185                "smithy.api#pattern": "^arn:(aws[a-zA-Z0-9-]*):emr-containers:.+:(\\d{12}):\\/virtualclusters\\/[0-9a-zA-Z]+$"
2186            }
2187        },
2188        "com.amazonaws.emrcontainers#VirtualClusterState": {
2189            "type": "string",
2190            "traits": {
2191                "smithy.api#enum": [
2192                    {
2193                        "value": "RUNNING",
2194                        "name": "RUNNING"
2195                    },
2196                    {
2197                        "value": "TERMINATING",
2198                        "name": "TERMINATING"
2199                    },
2200                    {
2201                        "value": "TERMINATED",
2202                        "name": "TERMINATED"
2203                    },
2204                    {
2205                        "value": "ARRESTED",
2206                        "name": "ARRESTED"
2207                    }
2208                ]
2209            }
2210        },
2211        "com.amazonaws.emrcontainers#VirtualClusterStates": {
2212            "type": "list",
2213            "member": {
2214                "target": "com.amazonaws.emrcontainers#VirtualClusterState"
2215            },
2216            "traits": {
2217                "smithy.api#length": {
2218                    "min": 0,
2219                    "max": 10
2220                }
2221            }
2222        },
2223        "com.amazonaws.emrcontainers#VirtualClusters": {
2224            "type": "list",
2225            "member": {
2226                "target": "com.amazonaws.emrcontainers#VirtualCluster"
2227            }
2228        }
2229    }
2230}
2231