import {Request} from '../lib/request'; import {Response} from '../lib/response'; import {AWSError} from '../lib/error'; import {Service} from '../lib/service'; import {ServiceConfigurationOptions} from '../lib/service'; import {ConfigBase as Config} from '../lib/config-base'; interface Blob {} declare class EMRcontainers extends Service { /** * Constructs a service object. This object has one method for each API operation. */ constructor(options?: EMRcontainers.Types.ClientConfiguration) config: Config & EMRcontainers.Types.ClientConfiguration; /** * 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. */ cancelJobRun(params: EMRcontainers.Types.CancelJobRunRequest, callback?: (err: AWSError, data: EMRcontainers.Types.CancelJobRunResponse) => void): Request; /** * 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. */ cancelJobRun(callback?: (err: AWSError, data: EMRcontainers.Types.CancelJobRunResponse) => void): Request; /** * Creates a job template. Job template stores values of StartJobRun API request in a template and can be used to start a job run. Job template allows two use cases: avoid repeating recurring StartJobRun API request values, enforcing certain values in StartJobRun API request. */ createJobTemplate(params: EMRcontainers.Types.CreateJobTemplateRequest, callback?: (err: AWSError, data: EMRcontainers.Types.CreateJobTemplateResponse) => void): Request; /** * Creates a job template. Job template stores values of StartJobRun API request in a template and can be used to start a job run. Job template allows two use cases: avoid repeating recurring StartJobRun API request values, enforcing certain values in StartJobRun API request. */ createJobTemplate(callback?: (err: AWSError, data: EMRcontainers.Types.CreateJobTemplateResponse) => void): Request; /** * Creates a managed endpoint. A managed endpoint is a gateway that connects Amazon EMR Studio to Amazon EMR on EKS so that Amazon EMR Studio can communicate with your virtual cluster. */ createManagedEndpoint(params: EMRcontainers.Types.CreateManagedEndpointRequest, callback?: (err: AWSError, data: EMRcontainers.Types.CreateManagedEndpointResponse) => void): Request; /** * Creates a managed endpoint. A managed endpoint is a gateway that connects Amazon EMR Studio to Amazon EMR on EKS so that Amazon EMR Studio can communicate with your virtual cluster. */ createManagedEndpoint(callback?: (err: AWSError, data: EMRcontainers.Types.CreateManagedEndpointResponse) => void): Request; /** * Creates a security configuration. Security configurations in Amazon EMR on EKS are templates for different security setups. You can use security configurations to configure the Lake Formation integration setup. You can also create a security configuration to re-use a security setup each time you create a virtual cluster. */ createSecurityConfiguration(params: EMRcontainers.Types.CreateSecurityConfigurationRequest, callback?: (err: AWSError, data: EMRcontainers.Types.CreateSecurityConfigurationResponse) => void): Request; /** * Creates a security configuration. Security configurations in Amazon EMR on EKS are templates for different security setups. You can use security configurations to configure the Lake Formation integration setup. You can also create a security configuration to re-use a security setup each time you create a virtual cluster. */ createSecurityConfiguration(callback?: (err: AWSError, data: EMRcontainers.Types.CreateSecurityConfigurationResponse) => void): Request; /** * 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. */ createVirtualCluster(params: EMRcontainers.Types.CreateVirtualClusterRequest, callback?: (err: AWSError, data: EMRcontainers.Types.CreateVirtualClusterResponse) => void): Request; /** * 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. */ createVirtualCluster(callback?: (err: AWSError, data: EMRcontainers.Types.CreateVirtualClusterResponse) => void): Request; /** * Deletes a job template. Job template stores values of StartJobRun API request in a template and can be used to start a job run. Job template allows two use cases: avoid repeating recurring StartJobRun API request values, enforcing certain values in StartJobRun API request. */ deleteJobTemplate(params: EMRcontainers.Types.DeleteJobTemplateRequest, callback?: (err: AWSError, data: EMRcontainers.Types.DeleteJobTemplateResponse) => void): Request; /** * Deletes a job template. Job template stores values of StartJobRun API request in a template and can be used to start a job run. Job template allows two use cases: avoid repeating recurring StartJobRun API request values, enforcing certain values in StartJobRun API request. */ deleteJobTemplate(callback?: (err: AWSError, data: EMRcontainers.Types.DeleteJobTemplateResponse) => void): Request; /** * Deletes a managed endpoint. A managed endpoint is a gateway that connects Amazon EMR Studio to Amazon EMR on EKS so that Amazon EMR Studio can communicate with your virtual cluster. */ deleteManagedEndpoint(params: EMRcontainers.Types.DeleteManagedEndpointRequest, callback?: (err: AWSError, data: EMRcontainers.Types.DeleteManagedEndpointResponse) => void): Request; /** * Deletes a managed endpoint. A managed endpoint is a gateway that connects Amazon EMR Studio to Amazon EMR on EKS so that Amazon EMR Studio can communicate with your virtual cluster. */ deleteManagedEndpoint(callback?: (err: AWSError, data: EMRcontainers.Types.DeleteManagedEndpointResponse) => void): Request; /** * 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. */ deleteVirtualCluster(params: EMRcontainers.Types.DeleteVirtualClusterRequest, callback?: (err: AWSError, data: EMRcontainers.Types.DeleteVirtualClusterResponse) => void): Request; /** * 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. */ deleteVirtualCluster(callback?: (err: AWSError, data: EMRcontainers.Types.DeleteVirtualClusterResponse) => void): Request; /** * 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. */ describeJobRun(params: EMRcontainers.Types.DescribeJobRunRequest, callback?: (err: AWSError, data: EMRcontainers.Types.DescribeJobRunResponse) => void): Request; /** * 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. */ describeJobRun(callback?: (err: AWSError, data: EMRcontainers.Types.DescribeJobRunResponse) => void): Request; /** * Displays detailed information about a specified job template. Job template stores values of StartJobRun API request in a template and can be used to start a job run. Job template allows two use cases: avoid repeating recurring StartJobRun API request values, enforcing certain values in StartJobRun API request. */ describeJobTemplate(params: EMRcontainers.Types.DescribeJobTemplateRequest, callback?: (err: AWSError, data: EMRcontainers.Types.DescribeJobTemplateResponse) => void): Request; /** * Displays detailed information about a specified job template. Job template stores values of StartJobRun API request in a template and can be used to start a job run. Job template allows two use cases: avoid repeating recurring StartJobRun API request values, enforcing certain values in StartJobRun API request. */ describeJobTemplate(callback?: (err: AWSError, data: EMRcontainers.Types.DescribeJobTemplateResponse) => void): Request; /** * Displays detailed information about a managed endpoint. A managed endpoint is a gateway that connects Amazon EMR Studio to Amazon EMR on EKS so that Amazon EMR Studio can communicate with your virtual cluster. */ describeManagedEndpoint(params: EMRcontainers.Types.DescribeManagedEndpointRequest, callback?: (err: AWSError, data: EMRcontainers.Types.DescribeManagedEndpointResponse) => void): Request; /** * Displays detailed information about a managed endpoint. A managed endpoint is a gateway that connects Amazon EMR Studio to Amazon EMR on EKS so that Amazon EMR Studio can communicate with your virtual cluster. */ describeManagedEndpoint(callback?: (err: AWSError, data: EMRcontainers.Types.DescribeManagedEndpointResponse) => void): Request; /** * Displays detailed information about a specified security configuration. Security configurations in Amazon EMR on EKS are templates for different security setups. You can use security configurations to configure the Lake Formation integration setup. You can also create a security configuration to re-use a security setup each time you create a virtual cluster. */ describeSecurityConfiguration(params: EMRcontainers.Types.DescribeSecurityConfigurationRequest, callback?: (err: AWSError, data: EMRcontainers.Types.DescribeSecurityConfigurationResponse) => void): Request; /** * Displays detailed information about a specified security configuration. Security configurations in Amazon EMR on EKS are templates for different security setups. You can use security configurations to configure the Lake Formation integration setup. You can also create a security configuration to re-use a security setup each time you create a virtual cluster. */ describeSecurityConfiguration(callback?: (err: AWSError, data: EMRcontainers.Types.DescribeSecurityConfigurationResponse) => void): Request; /** * 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. */ describeVirtualCluster(params: EMRcontainers.Types.DescribeVirtualClusterRequest, callback?: (err: AWSError, data: EMRcontainers.Types.DescribeVirtualClusterResponse) => void): Request; /** * 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. */ describeVirtualCluster(callback?: (err: AWSError, data: EMRcontainers.Types.DescribeVirtualClusterResponse) => void): Request; /** * Generate a session token to connect to a managed endpoint. */ getManagedEndpointSessionCredentials(params: EMRcontainers.Types.GetManagedEndpointSessionCredentialsRequest, callback?: (err: AWSError, data: EMRcontainers.Types.GetManagedEndpointSessionCredentialsResponse) => void): Request; /** * Generate a session token to connect to a managed endpoint. */ getManagedEndpointSessionCredentials(callback?: (err: AWSError, data: EMRcontainers.Types.GetManagedEndpointSessionCredentialsResponse) => void): Request; /** * 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. */ listJobRuns(params: EMRcontainers.Types.ListJobRunsRequest, callback?: (err: AWSError, data: EMRcontainers.Types.ListJobRunsResponse) => void): Request; /** * 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. */ listJobRuns(callback?: (err: AWSError, data: EMRcontainers.Types.ListJobRunsResponse) => void): Request; /** * Lists job templates based on a set of parameters. Job template stores values of StartJobRun API request in a template and can be used to start a job run. Job template allows two use cases: avoid repeating recurring StartJobRun API request values, enforcing certain values in StartJobRun API request. */ listJobTemplates(params: EMRcontainers.Types.ListJobTemplatesRequest, callback?: (err: AWSError, data: EMRcontainers.Types.ListJobTemplatesResponse) => void): Request; /** * Lists job templates based on a set of parameters. Job template stores values of StartJobRun API request in a template and can be used to start a job run. Job template allows two use cases: avoid repeating recurring StartJobRun API request values, enforcing certain values in StartJobRun API request. */ listJobTemplates(callback?: (err: AWSError, data: EMRcontainers.Types.ListJobTemplatesResponse) => void): Request; /** * Lists managed endpoints based on a set of parameters. A managed endpoint is a gateway that connects Amazon EMR Studio to Amazon EMR on EKS so that Amazon EMR Studio can communicate with your virtual cluster. */ listManagedEndpoints(params: EMRcontainers.Types.ListManagedEndpointsRequest, callback?: (err: AWSError, data: EMRcontainers.Types.ListManagedEndpointsResponse) => void): Request; /** * Lists managed endpoints based on a set of parameters. A managed endpoint is a gateway that connects Amazon EMR Studio to Amazon EMR on EKS so that Amazon EMR Studio can communicate with your virtual cluster. */ listManagedEndpoints(callback?: (err: AWSError, data: EMRcontainers.Types.ListManagedEndpointsResponse) => void): Request; /** * Lists security configurations based on a set of parameters. Security configurations in Amazon EMR on EKS are templates for different security setups. You can use security configurations to configure the Lake Formation integration setup. You can also create a security configuration to re-use a security setup each time you create a virtual cluster. */ listSecurityConfigurations(params: EMRcontainers.Types.ListSecurityConfigurationsRequest, callback?: (err: AWSError, data: EMRcontainers.Types.ListSecurityConfigurationsResponse) => void): Request; /** * Lists security configurations based on a set of parameters. Security configurations in Amazon EMR on EKS are templates for different security setups. You can use security configurations to configure the Lake Formation integration setup. You can also create a security configuration to re-use a security setup each time you create a virtual cluster. */ listSecurityConfigurations(callback?: (err: AWSError, data: EMRcontainers.Types.ListSecurityConfigurationsResponse) => void): Request; /** * Lists the tags assigned to the resources. */ listTagsForResource(params: EMRcontainers.Types.ListTagsForResourceRequest, callback?: (err: AWSError, data: EMRcontainers.Types.ListTagsForResourceResponse) => void): Request; /** * Lists the tags assigned to the resources. */ listTagsForResource(callback?: (err: AWSError, data: EMRcontainers.Types.ListTagsForResourceResponse) => void): Request; /** * 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. */ listVirtualClusters(params: EMRcontainers.Types.ListVirtualClustersRequest, callback?: (err: AWSError, data: EMRcontainers.Types.ListVirtualClustersResponse) => void): Request; /** * 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. */ listVirtualClusters(callback?: (err: AWSError, data: EMRcontainers.Types.ListVirtualClustersResponse) => void): Request; /** * 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. */ startJobRun(params: EMRcontainers.Types.StartJobRunRequest, callback?: (err: AWSError, data: EMRcontainers.Types.StartJobRunResponse) => void): Request; /** * 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. */ startJobRun(callback?: (err: AWSError, data: EMRcontainers.Types.StartJobRunResponse) => void): Request; /** * Assigns tags to resources. A tag is a label that you assign to an Amazon Web Services resource. Each tag consists of a key and an optional value, both of which you define. Tags enable you to categorize your Amazon Web Services 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. */ tagResource(params: EMRcontainers.Types.TagResourceRequest, callback?: (err: AWSError, data: EMRcontainers.Types.TagResourceResponse) => void): Request; /** * Assigns tags to resources. A tag is a label that you assign to an Amazon Web Services resource. Each tag consists of a key and an optional value, both of which you define. Tags enable you to categorize your Amazon Web Services 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. */ tagResource(callback?: (err: AWSError, data: EMRcontainers.Types.TagResourceResponse) => void): Request; /** * Removes tags from resources. */ untagResource(params: EMRcontainers.Types.UntagResourceRequest, callback?: (err: AWSError, data: EMRcontainers.Types.UntagResourceResponse) => void): Request; /** * Removes tags from resources. */ untagResource(callback?: (err: AWSError, data: EMRcontainers.Types.UntagResourceResponse) => void): Request; } declare namespace EMRcontainers { export type ACMCertArn = string; export interface AuthorizationConfiguration { /** * Lake Formation related configuration inputs for the security configuration. */ lakeFormationConfiguration?: LakeFormationConfiguration; /** * Encryption-related configuration input for the security configuration. */ encryptionConfiguration?: EncryptionConfiguration; } export type Base64Encoded = string; export type Boolean = boolean; export interface CancelJobRunRequest { /** * The ID of the job run to cancel. */ id: ResourceIdString; /** * The ID of the virtual cluster for which the job run will be canceled. */ virtualClusterId: ResourceIdString; } export interface CancelJobRunResponse { /** * The output contains the ID of the cancelled job run. */ id?: ResourceIdString; /** * The output contains the virtual cluster ID for which the job run is cancelled. */ virtualClusterId?: ResourceIdString; } export interface Certificate { /** * The ARN of the certificate generated for managed endpoint. */ certificateArn?: ACMCertArn; /** * The base64 encoded PEM certificate data generated for managed endpoint. */ certificateData?: Base64Encoded; } export type CertificateProviderType = "PEM"|string; export type ClientToken = string; export interface CloudWatchMonitoringConfiguration { /** * The name of the log group for log publishing. */ logGroupName: LogGroupName; /** * The specified name prefix for log streams. */ logStreamNamePrefix?: String256; } export type ClusterId = string; export interface Configuration { /** * The classification within a configuration. */ classification: String1024; /** * A set of properties specified within a configuration classification. */ properties?: SensitivePropertiesMap; /** * A list of additional configurations to apply within a configuration object. */ configurations?: ConfigurationList; } export type ConfigurationList = Configuration[]; export interface ConfigurationOverrides { /** * The configurations for the application running by the job run. */ applicationConfiguration?: ConfigurationList; /** * The configurations for monitoring. */ monitoringConfiguration?: MonitoringConfiguration; } export interface ContainerInfo { /** * The information about the Amazon EKS cluster. */ eksInfo?: EksInfo; } export interface ContainerLogRotationConfiguration { /** * The file size at which to rotate logs. Minimum of 2KB, Maximum of 2GB. */ rotationSize: RotationSize; /** * The number of files to keep in container after rotation. */ maxFilesToKeep: MaxFilesToKeep; } export interface ContainerProvider { /** * The type of the container provider. Amazon EKS is the only supported type as of now. */ type: ContainerProviderType; /** * The ID of the container cluster. */ id: ClusterId; /** * The information about the container cluster. */ info?: ContainerInfo; } export type ContainerProviderType = "EKS"|string; export interface CreateJobTemplateRequest { /** * The specified name of the job template. */ name: ResourceNameString; /** * The client token of the job template. */ clientToken: ClientToken; /** * The job template data which holds values of StartJobRun API request. */ jobTemplateData: JobTemplateData; /** * The tags that are associated with the job template. */ tags?: TagMap; /** * The KMS key ARN used to encrypt the job template. */ kmsKeyArn?: KmsKeyArn; } export interface CreateJobTemplateResponse { /** * This output display the created job template ID. */ id?: ResourceIdString; /** * This output displays the name of the created job template. */ name?: ResourceNameString; /** * This output display the ARN of the created job template. */ arn?: JobTemplateArn; /** * This output displays the date and time when the job template was created. */ createdAt?: _Date; } export interface CreateManagedEndpointRequest { /** * The name of the managed endpoint. */ name: ResourceNameString; /** * The ID of the virtual cluster for which a managed endpoint is created. */ virtualClusterId: ResourceIdString; /** * The type of the managed endpoint. */ type: EndpointType; /** * The Amazon EMR release version. */ releaseLabel: ReleaseLabel; /** * The ARN of the execution role. */ executionRoleArn: IAMRoleArn; /** * The certificate ARN provided by users for the managed endpoint. This field is under deprecation and will be removed in future releases. */ certificateArn?: ACMCertArn; /** * The configuration settings that will be used to override existing configurations. */ configurationOverrides?: ConfigurationOverrides; /** * The client idempotency token for this create call. */ clientToken: ClientToken; /** * The tags of the managed endpoint. */ tags?: TagMap; } export interface CreateManagedEndpointResponse { /** * The output contains the ID of the managed endpoint. */ id?: ResourceIdString; /** * The output contains the name of the managed endpoint. */ name?: ResourceNameString; /** * The output contains the ARN of the managed endpoint. */ arn?: EndpointArn; /** * The output contains the ID of the virtual cluster. */ virtualClusterId?: ResourceIdString; } export interface CreateSecurityConfigurationRequest { /** * The client idempotency token to use when creating the security configuration. */ clientToken: ClientToken; /** * The name of the security configuration. */ name: ResourceNameString; /** * Security configuration input for the request. */ securityConfigurationData: SecurityConfigurationData; /** * The tags to add to the security configuration. */ tags?: TagMap; } export interface CreateSecurityConfigurationResponse { /** * The ID of the security configuration. */ id?: ResourceIdString; /** * The name of the security configuration. */ name?: ResourceNameString; /** * The ARN (Amazon Resource Name) of the security configuration. */ arn?: SecurityConfigurationArn; } export interface CreateVirtualClusterRequest { /** * The specified name of the virtual cluster. */ name: ResourceNameString; /** * The container provider of the virtual cluster. */ containerProvider: ContainerProvider; /** * The client token of the virtual cluster. */ clientToken: ClientToken; /** * The tags assigned to the virtual cluster. */ tags?: TagMap; /** * The ID of the security configuration. */ securityConfigurationId?: ResourceIdString; } export interface CreateVirtualClusterResponse { /** * This output contains the virtual cluster ID. */ id?: ResourceIdString; /** * This output contains the name of the virtual cluster. */ name?: ResourceNameString; /** * This output contains the ARN of virtual cluster. */ arn?: VirtualClusterArn; } export type CredentialType = string; export interface Credentials { /** * The actual session token being returned. */ token?: Token; } export type _Date = Date; export interface DeleteJobTemplateRequest { /** * The ID of the job template that will be deleted. */ id: ResourceIdString; } export interface DeleteJobTemplateResponse { /** * This output contains the ID of the job template that was deleted. */ id?: ResourceIdString; } export interface DeleteManagedEndpointRequest { /** * The ID of the managed endpoint. */ id: ResourceIdString; /** * The ID of the endpoint's virtual cluster. */ virtualClusterId: ResourceIdString; } export interface DeleteManagedEndpointResponse { /** * The output displays the ID of the managed endpoint. */ id?: ResourceIdString; /** * The output displays the ID of the endpoint's virtual cluster. */ virtualClusterId?: ResourceIdString; } export interface DeleteVirtualClusterRequest { /** * The ID of the virtual cluster that will be deleted. */ id: ResourceIdString; } export interface DeleteVirtualClusterResponse { /** * This output contains the ID of the virtual cluster that will be deleted. */ id?: ResourceIdString; } export interface DescribeJobRunRequest { /** * The ID of the job run request. */ id: ResourceIdString; /** * The ID of the virtual cluster for which the job run is submitted. */ virtualClusterId: ResourceIdString; } export interface DescribeJobRunResponse { /** * The output displays information about a job run. */ jobRun?: JobRun; } export interface DescribeJobTemplateRequest { /** * The ID of the job template that will be described. */ id: ResourceIdString; } export interface DescribeJobTemplateResponse { /** * This output displays information about the specified job template. */ jobTemplate?: JobTemplate; } export interface DescribeManagedEndpointRequest { /** * This output displays ID of the managed endpoint. */ id: ResourceIdString; /** * The ID of the endpoint's virtual cluster. */ virtualClusterId: ResourceIdString; } export interface DescribeManagedEndpointResponse { /** * This output displays information about a managed endpoint. */ endpoint?: Endpoint; } export interface DescribeSecurityConfigurationRequest { /** * The ID of the security configuration. */ id: ResourceIdString; } export interface DescribeSecurityConfigurationResponse { /** * Details of the security configuration. */ securityConfiguration?: SecurityConfiguration; } export interface DescribeVirtualClusterRequest { /** * The ID of the virtual cluster that will be described. */ id: ResourceIdString; } export interface DescribeVirtualClusterResponse { /** * This output displays information about the specified virtual cluster. */ virtualCluster?: VirtualCluster; } export interface EksInfo { /** * The namespaces of the Amazon EKS cluster. */ namespace?: KubernetesNamespace; } export interface EncryptionConfiguration { /** * In-transit encryption-related input for the security configuration. */ inTransitEncryptionConfiguration?: InTransitEncryptionConfiguration; } export interface Endpoint { /** * The ID of the endpoint. */ id?: ResourceIdString; /** * The name of the endpoint. */ name?: ResourceNameString; /** * The ARN of the endpoint. */ arn?: EndpointArn; /** * The ID of the endpoint's virtual cluster. */ virtualClusterId?: ResourceIdString; /** * The type of the endpoint. */ type?: EndpointType; /** * The state of the endpoint. */ state?: EndpointState; /** * The EMR release version to be used for the endpoint. */ releaseLabel?: ReleaseLabel; /** * The execution role ARN of the endpoint. */ executionRoleArn?: IAMRoleArn; /** * The certificate ARN of the endpoint. This field is under deprecation and will be removed in future. */ certificateArn?: ACMCertArn; /** * The certificate generated by emr control plane on customer behalf to secure the managed endpoint. */ certificateAuthority?: Certificate; /** * The configuration settings that are used to override existing configurations for endpoints. */ configurationOverrides?: ConfigurationOverrides; /** * The server URL of the endpoint. */ serverUrl?: UriString; /** * The date and time when the endpoint was created. */ createdAt?: _Date; /** * The security group configuration of the endpoint. */ securityGroup?: String256; /** * The subnet IDs of the endpoint. */ subnetIds?: SubnetIds; /** * Additional details of the endpoint state. */ stateDetails?: String256; /** * The reasons why the endpoint has failed. */ failureReason?: FailureReason; /** * The tags of the endpoint. */ tags?: TagMap; } export type EndpointArn = string; export type EndpointState = "CREATING"|"ACTIVE"|"TERMINATING"|"TERMINATED"|"TERMINATED_WITH_ERRORS"|string; export type EndpointStates = EndpointState[]; export type EndpointType = string; export type EndpointTypes = EndpointType[]; export type Endpoints = Endpoint[]; export type EntryPointArgument = string; export type EntryPointArguments = EntryPointArgument[]; export type EntryPointPath = string; export type FailureReason = "INTERNAL_ERROR"|"USER_ERROR"|"VALIDATION_ERROR"|"CLUSTER_UNAVAILABLE"|string; export interface GetManagedEndpointSessionCredentialsRequest { /** * The ARN of the managed endpoint for which the request is submitted. */ endpointIdentifier: String2048; /** * The ARN of the Virtual Cluster which the Managed Endpoint belongs to. */ virtualClusterIdentifier: String2048; /** * The IAM Execution Role ARN that will be used by the job run. */ executionRoleArn: IAMRoleArn; /** * Type of the token requested. Currently supported and default value of this field is “TOKEN.” */ credentialType: CredentialType; /** * Duration in seconds for which the session token is valid. The default duration is 15 minutes and the maximum is 12 hours. */ durationInSeconds?: JavaInteger; /** * String identifier used to separate sections of the execution logs uploaded to S3. */ logContext?: LogContext; /** * The client idempotency token of the job run request. */ clientToken?: ClientToken; } export interface GetManagedEndpointSessionCredentialsResponse { /** * The identifier of the session token returned. */ id?: ResourceIdString; /** * The structure containing the session credentials. */ credentials?: Credentials; /** * The date and time when the session token will expire. */ expiresAt?: _Date; } export type IAMRoleArn = string; export interface InTransitEncryptionConfiguration { /** * TLS certificate-related configuration input for the security configuration. */ tlsCertificateConfiguration?: TLSCertificateConfiguration; } export type JavaInteger = number; export type JobArn = string; export interface JobDriver { /** * The job driver parameters specified for spark submit. */ sparkSubmitJobDriver?: SparkSubmitJobDriver; /** * The job driver for job type. */ sparkSqlJobDriver?: SparkSqlJobDriver; } export interface JobRun { /** * The ID of the job run. */ id?: ResourceIdString; /** * The name of the job run. */ name?: ResourceNameString; /** * The ID of the job run's virtual cluster. */ virtualClusterId?: ResourceIdString; /** * The ARN of job run. */ arn?: JobArn; /** * The state of the job run. */ state?: JobRunState; /** * The client token used to start a job run. */ clientToken?: ClientToken; /** * The execution role ARN of the job run. */ executionRoleArn?: IAMRoleArn; /** * The release version of Amazon EMR. */ releaseLabel?: ReleaseLabel; /** * The configuration settings that are used to override default configuration. */ configurationOverrides?: ConfigurationOverrides; /** * Parameters of job driver for the job run. */ jobDriver?: JobDriver; /** * The date and time when the job run was created. */ createdAt?: _Date; /** * The user who created the job run. */ createdBy?: RequestIdentityUserArn; /** * The date and time when the job run has finished. */ finishedAt?: _Date; /** * Additional details of the job run state. */ stateDetails?: String256; /** * The reasons why the job run has failed. */ failureReason?: FailureReason; /** * The assigned tags of the job run. */ tags?: TagMap; /** * The configuration of the retry policy that the job runs on. */ retryPolicyConfiguration?: RetryPolicyConfiguration; /** * The current status of the retry policy executed on the job. */ retryPolicyExecution?: RetryPolicyExecution; } export type JobRunState = "PENDING"|"SUBMITTED"|"RUNNING"|"FAILED"|"CANCELLED"|"CANCEL_PENDING"|"COMPLETED"|string; export type JobRunStates = JobRunState[]; export type JobRuns = JobRun[]; export interface JobTemplate { /** * The name of the job template. */ name?: ResourceNameString; /** * The ID of the job template. */ id?: ResourceIdString; /** * The ARN of the job template. */ arn?: JobTemplateArn; /** * The date and time when the job template was created. */ createdAt?: _Date; /** * The user who created the job template. */ createdBy?: RequestIdentityUserArn; /** * The tags assigned to the job template. */ tags?: TagMap; /** * The job template data which holds values of StartJobRun API request. */ jobTemplateData: JobTemplateData; /** * The KMS key ARN used to encrypt the job template. */ kmsKeyArn?: KmsKeyArn; /** * The error message in case the decryption of job template fails. */ decryptionError?: String2048; } export type JobTemplateArn = string; export interface JobTemplateData { /** * The execution role ARN of the job run. */ executionRoleArn: ParametricIAMRoleArn; /** * The release version of Amazon EMR. */ releaseLabel: ParametricReleaseLabel; /** * The configuration settings that are used to override defaults configuration. */ configurationOverrides?: ParametricConfigurationOverrides; jobDriver: JobDriver; /** * The configuration of parameters existing in the job template. */ parameterConfiguration?: TemplateParameterConfigurationMap; /** * The tags assigned to jobs started using the job template. */ jobTags?: TagMap; } export type JobTemplates = JobTemplate[]; export type KmsKeyArn = string; export type KubernetesNamespace = string; export interface LakeFormationConfiguration { /** * The session tag to authorize Amazon EMR on EKS for API calls to Lake Formation. */ authorizedSessionTagValue?: SessionTagValue; /** * The namespace input of the system job. */ secureNamespaceInfo?: SecureNamespaceInfo; /** * The query engine IAM role ARN that is tied to the secure Spark job. The QueryEngine role assumes the JobExecutionRole to execute all the Lake Formation calls. */ queryEngineRoleArn?: IAMRoleArn; } export interface ListJobRunsRequest { /** * The ID of the virtual cluster for which to list the job run. */ virtualClusterId: ResourceIdString; /** * The date and time before which the job runs were submitted. */ createdBefore?: _Date; /** * The date and time after which the job runs were submitted. */ createdAfter?: _Date; /** * The name of the job run. */ name?: ResourceNameString; /** * The states of the job run. */ states?: JobRunStates; /** * The maximum number of job runs that can be listed. */ maxResults?: JavaInteger; /** * The token for the next set of job runs to return. */ nextToken?: NextToken; } export interface ListJobRunsResponse { /** * This output lists information about the specified job runs. */ jobRuns?: JobRuns; /** * This output displays the token for the next set of job runs. */ nextToken?: NextToken; } export interface ListJobTemplatesRequest { /** * The date and time after which the job templates were created. */ createdAfter?: _Date; /** * The date and time before which the job templates were created. */ createdBefore?: _Date; /** * The maximum number of job templates that can be listed. */ maxResults?: JavaInteger; /** * The token for the next set of job templates to return. */ nextToken?: NextToken; } export interface ListJobTemplatesResponse { /** * This output lists information about the specified job templates. */ templates?: JobTemplates; /** * This output displays the token for the next set of job templates. */ nextToken?: NextToken; } export interface ListManagedEndpointsRequest { /** * The ID of the virtual cluster. */ virtualClusterId: ResourceIdString; /** * The date and time before which the endpoints are created. */ createdBefore?: _Date; /** * The date and time after which the endpoints are created. */ createdAfter?: _Date; /** * The types of the managed endpoints. */ types?: EndpointTypes; /** * The states of the managed endpoints. */ states?: EndpointStates; /** * The maximum number of managed endpoints that can be listed. */ maxResults?: JavaInteger; /** * The token for the next set of managed endpoints to return. */ nextToken?: NextToken; } export interface ListManagedEndpointsResponse { /** * The managed endpoints to be listed. */ endpoints?: Endpoints; /** * The token for the next set of endpoints to return. */ nextToken?: NextToken; } export interface ListSecurityConfigurationsRequest { /** * The date and time after which the security configuration was created. */ createdAfter?: _Date; /** * The date and time before which the security configuration was created. */ createdBefore?: _Date; /** * The maximum number of security configurations the operation can list. */ maxResults?: JavaInteger; /** * The token for the next set of security configurations to return. */ nextToken?: NextToken; } export interface ListSecurityConfigurationsResponse { /** * The list of returned security configurations. */ securityConfigurations?: SecurityConfigurations; /** * The token for the next set of security configurations to return. */ nextToken?: NextToken; } export interface ListTagsForResourceRequest { /** * The ARN of tagged resources. */ resourceArn: RsiArn; } export interface ListTagsForResourceResponse { /** * The tags assigned to resources. */ tags?: TagMap; } export interface ListVirtualClustersRequest { /** * The container provider ID of the virtual cluster. */ containerProviderId?: String1024; /** * The container provider type of the virtual cluster. Amazon EKS is the only supported type as of now. */ containerProviderType?: ContainerProviderType; /** * The date and time after which the virtual clusters are created. */ createdAfter?: _Date; /** * The date and time before which the virtual clusters are created. */ createdBefore?: _Date; /** * The states of the requested virtual clusters. */ states?: VirtualClusterStates; /** * The maximum number of virtual clusters that can be listed. */ maxResults?: JavaInteger; /** * The token for the next set of virtual clusters to return. */ nextToken?: NextToken; /** * Optional Boolean that specifies whether the operation should return the virtual clusters that have the access entry integration enabled or disabled. If not specified, the operation returns all applicable virtual clusters. */ eksAccessEntryIntegrated?: Boolean; } export interface ListVirtualClustersResponse { /** * This output lists the specified virtual clusters. */ virtualClusters?: VirtualClusters; /** * This output displays the token for the next set of virtual clusters. */ nextToken?: NextToken; } export type LogContext = string; export type LogGroupName = string; export type MaxFilesToKeep = number; export interface MonitoringConfiguration { /** * Monitoring configurations for the persistent application UI. */ persistentAppUI?: PersistentAppUI; /** * Monitoring configurations for CloudWatch. */ cloudWatchMonitoringConfiguration?: CloudWatchMonitoringConfiguration; /** * Amazon S3 configuration for monitoring log publishing. */ s3MonitoringConfiguration?: S3MonitoringConfiguration; /** * Enable or disable container log rotation. */ containerLogRotationConfiguration?: ContainerLogRotationConfiguration; } export type NextToken = string; export interface ParametricCloudWatchMonitoringConfiguration { /** * The name of the log group for log publishing. */ logGroupName?: TemplateParameter; /** * The specified name prefix for log streams. */ logStreamNamePrefix?: String256; } export interface ParametricConfigurationOverrides { /** * The configurations for the application running by the job run. */ applicationConfiguration?: ConfigurationList; /** * The configurations for monitoring. */ monitoringConfiguration?: ParametricMonitoringConfiguration; } export type ParametricIAMRoleArn = string; export interface ParametricMonitoringConfiguration { /** * Monitoring configurations for the persistent application UI. */ persistentAppUI?: TemplateParameter; /** * Monitoring configurations for CloudWatch. */ cloudWatchMonitoringConfiguration?: ParametricCloudWatchMonitoringConfiguration; /** * Amazon S3 configuration for monitoring log publishing. */ s3MonitoringConfiguration?: ParametricS3MonitoringConfiguration; } export type ParametricReleaseLabel = string; export interface ParametricS3MonitoringConfiguration { /** * Amazon S3 destination URI for log publishing. */ logUri?: UriString; } export type PersistentAppUI = "ENABLED"|"DISABLED"|string; export type ReleaseLabel = string; export type RequestIdentityUserArn = string; export type ResourceIdString = string; export type ResourceNameString = string; export interface RetryPolicyConfiguration { /** * The maximum number of attempts on the job's driver. */ maxAttempts: JavaInteger; } export interface RetryPolicyExecution { /** * The current number of attempts made on the driver of the job. */ currentAttemptCount: JavaInteger; } export type RotationSize = string; export type RsiArn = string; export interface S3MonitoringConfiguration { /** * Amazon S3 destination URI for log publishing. */ logUri: UriString; } export type SecretsManagerArn = string; export interface SecureNamespaceInfo { /** * The ID of the Amazon EKS cluster where Amazon EMR on EKS jobs run. */ clusterId?: ClusterId; /** * The namespace of the Amazon EKS cluster where the system jobs run. */ namespace?: KubernetesNamespace; } export interface SecurityConfiguration { /** * The ID of the security configuration. */ id?: ResourceIdString; /** * The name of the security configuration. */ name?: ResourceNameString; /** * The ARN (Amazon Resource Name) of the security configuration. */ arn?: SecurityConfigurationArn; /** * The date and time that the job run was created. */ createdAt?: _Date; /** * The user who created the job run. */ createdBy?: RequestIdentityUserArn; /** * Security configuration inputs for the request. */ securityConfigurationData?: SecurityConfigurationData; /** * The tags to assign to the security configuration. */ tags?: TagMap; } export type SecurityConfigurationArn = string; export interface SecurityConfigurationData { /** * Authorization-related configuration input for the security configuration. */ authorizationConfiguration?: AuthorizationConfiguration; } export type SecurityConfigurations = SecurityConfiguration[]; export type SensitivePropertiesMap = {[key: string]: String1024}; export type SessionTagValue = string; export interface SparkSqlJobDriver { /** * The SQL file to be executed. */ entryPoint?: EntryPointPath; /** * The Spark parameters to be included in the Spark SQL command. */ sparkSqlParameters?: SparkSqlParameters; } export type SparkSqlParameters = string; export interface SparkSubmitJobDriver { /** * The entry point of job application. */ entryPoint: EntryPointPath; /** * The arguments for job application. */ entryPointArguments?: EntryPointArguments; /** * The Spark submit parameters that are used for job runs. */ sparkSubmitParameters?: SparkSubmitParameters; } export type SparkSubmitParameters = string; export interface StartJobRunRequest { /** * The name of the job run. */ name?: ResourceNameString; /** * The virtual cluster ID for which the job run request is submitted. */ virtualClusterId: ResourceIdString; /** * The client idempotency token of the job run request. */ clientToken: ClientToken; /** * The execution role ARN for the job run. */ executionRoleArn?: IAMRoleArn; /** * The Amazon EMR release version to use for the job run. */ releaseLabel?: ReleaseLabel; /** * The job driver for the job run. */ jobDriver?: JobDriver; /** * The configuration overrides for the job run. */ configurationOverrides?: ConfigurationOverrides; /** * The tags assigned to job runs. */ tags?: TagMap; /** * The job template ID to be used to start the job run. */ jobTemplateId?: ResourceIdString; /** * The values of job template parameters to start a job run. */ jobTemplateParameters?: TemplateParameterInputMap; /** * The retry policy configuration for the job run. */ retryPolicyConfiguration?: RetryPolicyConfiguration; } export interface StartJobRunResponse { /** * This output displays the started job run ID. */ id?: ResourceIdString; /** * This output displays the name of the started job run. */ name?: ResourceNameString; /** * This output lists the ARN of job run. */ arn?: JobArn; /** * This output displays the virtual cluster ID for which the job run was submitted. */ virtualClusterId?: ResourceIdString; } export type String1024 = string; export type String128 = string; export type String2048 = string; export type String256 = string; export type StringEmpty256 = string; export type SubnetIds = String256[]; export interface TLSCertificateConfiguration { /** * The TLS certificate type. Acceptable values: PEM or Custom. */ certificateProviderType?: CertificateProviderType; /** * Secrets Manager ARN that contains the public TLS certificate contents, used for communication between the user job and the system job. */ publicCertificateSecretArn?: SecretsManagerArn; /** * Secrets Manager ARN that contains the private TLS certificate contents, used for communication between the user job and the system job. */ privateCertificateSecretArn?: SecretsManagerArn; } export type TagKeyList = String128[]; export type TagMap = {[key: string]: StringEmpty256}; export interface TagResourceRequest { /** * The ARN of resources. */ resourceArn: RsiArn; /** * The tags assigned to resources. */ tags: TagMap; } export interface TagResourceResponse { } export type TemplateParameter = string; export interface TemplateParameterConfiguration { /** * The type of the job template parameter. Allowed values are: ‘STRING’, ‘NUMBER’. */ type?: TemplateParameterDataType; /** * The default value for the job template parameter. */ defaultValue?: String1024; } export type TemplateParameterConfigurationMap = {[key: string]: TemplateParameterConfiguration}; export type TemplateParameterDataType = "NUMBER"|"STRING"|string; export type TemplateParameterInputMap = {[key: string]: String1024}; export type TemplateParameterName = string; export type Token = string; export interface UntagResourceRequest { /** * The ARN of resources. */ resourceArn: RsiArn; /** * The tag keys of the resources. */ tagKeys: TagKeyList; } export interface UntagResourceResponse { } export type UriString = string; export interface VirtualCluster { /** * The ID of the virtual cluster. */ id?: ResourceIdString; /** * The name of the virtual cluster. */ name?: ResourceNameString; /** * The ARN of the virtual cluster. */ arn?: VirtualClusterArn; /** * The state of the virtual cluster. */ state?: VirtualClusterState; /** * The container provider of the virtual cluster. */ containerProvider?: ContainerProvider; /** * The date and time when the virtual cluster is created. */ createdAt?: _Date; /** * The assigned tags of the virtual cluster. */ tags?: TagMap; /** * The ID of the security configuration. */ securityConfigurationId?: ResourceIdString; } export type VirtualClusterArn = string; export type VirtualClusterState = "RUNNING"|"TERMINATING"|"TERMINATED"|"ARRESTED"|string; export type VirtualClusterStates = VirtualClusterState[]; export type VirtualClusters = VirtualCluster[]; /** * A string in YYYY-MM-DD format that represents the latest possible API version that can be used in this service. Specify 'latest' to use the latest possible version. */ export type apiVersion = "2020-10-01"|"latest"|string; export interface ClientApiVersions { /** * A string in YYYY-MM-DD format that represents the latest possible API version that can be used in this service. Specify 'latest' to use the latest possible version. */ apiVersion?: apiVersion; } export type ClientConfiguration = ServiceConfigurationOptions & ClientApiVersions; /** * Contains interfaces for use with the EMRcontainers client. */ export import Types = EMRcontainers; } export = EMRcontainers;