PNG  IHDR;IDATxܻn0K )(pA 7LeG{ §㻢|ذaÆ 6lذaÆ 6lذaÆ 6lom$^yذag5bÆ 6lذaÆ 6lذa{ 6lذaÆ `}HFkm,mӪôô! x|'ܢ˟;E:9&ᶒ}{v]n&6 h_tڠ͵-ҫZ;Z$.Pkž)!o>}leQfJTu іچ\X=8Rن4`Vwl>nG^is"ms$ui?wbs[m6K4O.4%/bC%t Mז -lG6mrz2s%9s@-k9=)kB5\+͂Zsٲ Rn~GRC wIcIn7jJhۛNCS|j08yiHKֶۛkɈ+;SzL/F*\Ԕ#"5m2[S=gnaPeғL lذaÆ 6l^ḵaÆ 6lذaÆ 6lذa; _ذaÆ 6lذaÆ 6lذaÆ RIENDB` package Paws::EMR; use Moose; sub service { 'elasticmapreduce' } sub signing_name { 'elasticmapreduce' } sub version { '2009-03-31' } sub target_prefix { 'ElasticMapReduce' } sub json_version { "1.1" } has max_attempts => (is => 'ro', isa => 'Int', default => 5); has retry => (is => 'ro', isa => 'HashRef', default => sub { { base => 'rand', type => 'exponential', growth_factor => 2 } }); has retriables => (is => 'ro', isa => 'ArrayRef', default => sub { [ ] }); with 'Paws::API::Caller', 'Paws::API::EndpointResolver', 'Paws::Net::V4Signature', 'Paws::Net::JsonCaller'; has '+region_rules' => (default => sub { my $regioninfo; $regioninfo = [ { constraints => [ [ 'region', 'startsWith', 'cn-' ] ], uri => 'https://elasticmapreduce.{region}.amazonaws.com.cn' }, { constraints => [ [ 'region', 'equals', 'eu-central-1' ] ], uri => 'https://elasticmapreduce.eu-central-1.amazonaws.com' }, { constraints => [ [ 'region', 'equals', 'us-east-1' ] ], uri => 'https://elasticmapreduce.us-east-1.amazonaws.com' }, { constraints => [ [ 'region', 'notEquals', undef ] ], uri => 'https://{region}.elasticmapreduce.amazonaws.com' } ]; return $regioninfo; }); sub AddInstanceFleet { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::AddInstanceFleet', @_); return $self->caller->do_call($self, $call_object); } sub AddInstanceGroups { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::AddInstanceGroups', @_); return $self->caller->do_call($self, $call_object); } sub AddJobFlowSteps { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::AddJobFlowSteps', @_); return $self->caller->do_call($self, $call_object); } sub AddTags { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::AddTags', @_); return $self->caller->do_call($self, $call_object); } sub CancelSteps { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::CancelSteps', @_); return $self->caller->do_call($self, $call_object); } sub CreateSecurityConfiguration { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::CreateSecurityConfiguration', @_); return $self->caller->do_call($self, $call_object); } sub CreateStudio { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::CreateStudio', @_); return $self->caller->do_call($self, $call_object); } sub CreateStudioSessionMapping { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::CreateStudioSessionMapping', @_); return $self->caller->do_call($self, $call_object); } sub DeleteSecurityConfiguration { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::DeleteSecurityConfiguration', @_); return $self->caller->do_call($self, $call_object); } sub DeleteStudio { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::DeleteStudio', @_); return $self->caller->do_call($self, $call_object); } sub DeleteStudioSessionMapping { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::DeleteStudioSessionMapping', @_); return $self->caller->do_call($self, $call_object); } sub DescribeCluster { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::DescribeCluster', @_); return $self->caller->do_call($self, $call_object); } sub DescribeJobFlows { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::DescribeJobFlows', @_); return $self->caller->do_call($self, $call_object); } sub DescribeNotebookExecution { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::DescribeNotebookExecution', @_); return $self->caller->do_call($self, $call_object); } sub DescribeSecurityConfiguration { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::DescribeSecurityConfiguration', @_); return $self->caller->do_call($self, $call_object); } sub DescribeStep { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::DescribeStep', @_); return $self->caller->do_call($self, $call_object); } sub DescribeStudio { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::DescribeStudio', @_); return $self->caller->do_call($self, $call_object); } sub GetBlockPublicAccessConfiguration { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::GetBlockPublicAccessConfiguration', @_); return $self->caller->do_call($self, $call_object); } sub GetManagedScalingPolicy { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::GetManagedScalingPolicy', @_); return $self->caller->do_call($self, $call_object); } sub GetStudioSessionMapping { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::GetStudioSessionMapping', @_); return $self->caller->do_call($self, $call_object); } sub ListBootstrapActions { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListBootstrapActions', @_); return $self->caller->do_call($self, $call_object); } sub ListClusters { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListClusters', @_); return $self->caller->do_call($self, $call_object); } sub ListInstanceFleets { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListInstanceFleets', @_); return $self->caller->do_call($self, $call_object); } sub ListInstanceGroups { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListInstanceGroups', @_); return $self->caller->do_call($self, $call_object); } sub ListInstances { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListInstances', @_); return $self->caller->do_call($self, $call_object); } sub ListNotebookExecutions { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListNotebookExecutions', @_); return $self->caller->do_call($self, $call_object); } sub ListSecurityConfigurations { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListSecurityConfigurations', @_); return $self->caller->do_call($self, $call_object); } sub ListSteps { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListSteps', @_); return $self->caller->do_call($self, $call_object); } sub ListStudios { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListStudios', @_); return $self->caller->do_call($self, $call_object); } sub ListStudioSessionMappings { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ListStudioSessionMappings', @_); return $self->caller->do_call($self, $call_object); } sub ModifyCluster { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ModifyCluster', @_); return $self->caller->do_call($self, $call_object); } sub ModifyInstanceFleet { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ModifyInstanceFleet', @_); return $self->caller->do_call($self, $call_object); } sub ModifyInstanceGroups { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::ModifyInstanceGroups', @_); return $self->caller->do_call($self, $call_object); } sub PutAutoScalingPolicy { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::PutAutoScalingPolicy', @_); return $self->caller->do_call($self, $call_object); } sub PutBlockPublicAccessConfiguration { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::PutBlockPublicAccessConfiguration', @_); return $self->caller->do_call($self, $call_object); } sub PutManagedScalingPolicy { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::PutManagedScalingPolicy', @_); return $self->caller->do_call($self, $call_object); } sub RemoveAutoScalingPolicy { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::RemoveAutoScalingPolicy', @_); return $self->caller->do_call($self, $call_object); } sub RemoveManagedScalingPolicy { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::RemoveManagedScalingPolicy', @_); return $self->caller->do_call($self, $call_object); } sub RemoveTags { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::RemoveTags', @_); return $self->caller->do_call($self, $call_object); } sub RunJobFlow { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::RunJobFlow', @_); return $self->caller->do_call($self, $call_object); } sub SetTerminationProtection { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::SetTerminationProtection', @_); return $self->caller->do_call($self, $call_object); } sub SetVisibleToAllUsers { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::SetVisibleToAllUsers', @_); return $self->caller->do_call($self, $call_object); } sub StartNotebookExecution { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::StartNotebookExecution', @_); return $self->caller->do_call($self, $call_object); } sub StopNotebookExecution { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::StopNotebookExecution', @_); return $self->caller->do_call($self, $call_object); } sub TerminateJobFlows { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::TerminateJobFlows', @_); return $self->caller->do_call($self, $call_object); } sub UpdateStudio { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::UpdateStudio', @_); return $self->caller->do_call($self, $call_object); } sub UpdateStudioSessionMapping { my $self = shift; my $call_object = $self->new_with_coercions('Paws::EMR::UpdateStudioSessionMapping', @_); return $self->caller->do_call($self, $call_object); } sub ListAllBootstrapActions { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListBootstrapActions(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListBootstrapActions(@_, Marker => $next_result->Marker); push @{ $result->BootstrapActions }, @{ $next_result->BootstrapActions }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'BootstrapActions') foreach (@{ $result->BootstrapActions }); $result = $self->ListBootstrapActions(@_, Marker => $result->Marker); } $callback->($_ => 'BootstrapActions') foreach (@{ $result->BootstrapActions }); } return undef } sub ListAllClusters { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListClusters(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListClusters(@_, Marker => $next_result->Marker); push @{ $result->Clusters }, @{ $next_result->Clusters }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'Clusters') foreach (@{ $result->Clusters }); $result = $self->ListClusters(@_, Marker => $result->Marker); } $callback->($_ => 'Clusters') foreach (@{ $result->Clusters }); } return undef } sub ListAllInstanceFleets { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListInstanceFleets(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListInstanceFleets(@_, Marker => $next_result->Marker); push @{ $result->InstanceFleets }, @{ $next_result->InstanceFleets }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'InstanceFleets') foreach (@{ $result->InstanceFleets }); $result = $self->ListInstanceFleets(@_, Marker => $result->Marker); } $callback->($_ => 'InstanceFleets') foreach (@{ $result->InstanceFleets }); } return undef } sub ListAllInstanceGroups { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListInstanceGroups(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListInstanceGroups(@_, Marker => $next_result->Marker); push @{ $result->InstanceGroups }, @{ $next_result->InstanceGroups }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'InstanceGroups') foreach (@{ $result->InstanceGroups }); $result = $self->ListInstanceGroups(@_, Marker => $result->Marker); } $callback->($_ => 'InstanceGroups') foreach (@{ $result->InstanceGroups }); } return undef } sub ListAllInstances { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListInstances(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListInstances(@_, Marker => $next_result->Marker); push @{ $result->Instances }, @{ $next_result->Instances }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'Instances') foreach (@{ $result->Instances }); $result = $self->ListInstances(@_, Marker => $result->Marker); } $callback->($_ => 'Instances') foreach (@{ $result->Instances }); } return undef } sub ListAllNotebookExecutions { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListNotebookExecutions(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListNotebookExecutions(@_, Marker => $next_result->Marker); push @{ $result->NotebookExecutions }, @{ $next_result->NotebookExecutions }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'NotebookExecutions') foreach (@{ $result->NotebookExecutions }); $result = $self->ListNotebookExecutions(@_, Marker => $result->Marker); } $callback->($_ => 'NotebookExecutions') foreach (@{ $result->NotebookExecutions }); } return undef } sub ListAllSecurityConfigurations { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListSecurityConfigurations(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListSecurityConfigurations(@_, Marker => $next_result->Marker); push @{ $result->SecurityConfigurations }, @{ $next_result->SecurityConfigurations }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'SecurityConfigurations') foreach (@{ $result->SecurityConfigurations }); $result = $self->ListSecurityConfigurations(@_, Marker => $result->Marker); } $callback->($_ => 'SecurityConfigurations') foreach (@{ $result->SecurityConfigurations }); } return undef } sub ListAllSteps { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListSteps(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListSteps(@_, Marker => $next_result->Marker); push @{ $result->Steps }, @{ $next_result->Steps }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'Steps') foreach (@{ $result->Steps }); $result = $self->ListSteps(@_, Marker => $result->Marker); } $callback->($_ => 'Steps') foreach (@{ $result->Steps }); } return undef } sub ListAllStudios { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListStudios(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListStudios(@_, Marker => $next_result->Marker); push @{ $result->Studios }, @{ $next_result->Studios }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'Studios') foreach (@{ $result->Studios }); $result = $self->ListStudios(@_, Marker => $result->Marker); } $callback->($_ => 'Studios') foreach (@{ $result->Studios }); } return undef } sub ListAllStudioSessionMappings { my $self = shift; my $callback = shift @_ if (ref($_[0]) eq 'CODE'); my $result = $self->ListStudioSessionMappings(@_); my $next_result = $result; if (not defined $callback) { while ($next_result->Marker) { $next_result = $self->ListStudioSessionMappings(@_, Marker => $next_result->Marker); push @{ $result->SessionMappings }, @{ $next_result->SessionMappings }; } return $result; } else { while ($result->Marker) { $callback->($_ => 'SessionMappings') foreach (@{ $result->SessionMappings }); $result = $self->ListStudioSessionMappings(@_, Marker => $result->Marker); } $callback->($_ => 'SessionMappings') foreach (@{ $result->SessionMappings }); } return undef } sub operations { qw/AddInstanceFleet AddInstanceGroups AddJobFlowSteps AddTags CancelSteps CreateSecurityConfiguration CreateStudio CreateStudioSessionMapping DeleteSecurityConfiguration DeleteStudio DeleteStudioSessionMapping DescribeCluster DescribeJobFlows DescribeNotebookExecution DescribeSecurityConfiguration DescribeStep DescribeStudio GetBlockPublicAccessConfiguration GetManagedScalingPolicy GetStudioSessionMapping ListBootstrapActions ListClusters ListInstanceFleets ListInstanceGroups ListInstances ListNotebookExecutions ListSecurityConfigurations ListSteps ListStudios ListStudioSessionMappings ModifyCluster ModifyInstanceFleet ModifyInstanceGroups PutAutoScalingPolicy PutBlockPublicAccessConfiguration PutManagedScalingPolicy RemoveAutoScalingPolicy RemoveManagedScalingPolicy RemoveTags RunJobFlow SetTerminationProtection SetVisibleToAllUsers StartNotebookExecution StopNotebookExecution TerminateJobFlows UpdateStudio UpdateStudioSessionMapping / } 1; ### main pod documentation begin ### =head1 NAME Paws::EMR - Perl Interface to AWS Amazon Elastic MapReduce =head1 SYNOPSIS use Paws; my $obj = Paws->service('EMR'); my $res = $obj->Method( Arg1 => $val1, Arg2 => [ 'V1', 'V2' ], # if Arg3 is an object, the HashRef will be used as arguments to the constructor # of the arguments type Arg3 => { Att1 => 'Val1' }, # if Arg4 is an array of objects, the HashRefs will be passed as arguments to # the constructor of the arguments type Arg4 => [ { Att1 => 'Val1' }, { Att1 => 'Val2' } ], ); =head1 DESCRIPTION Amazon EMR is a web service that makes it easier to process large amounts of data efficiently. Amazon EMR uses Hadoop processing combined with several AWS services to do tasks such as web indexing, data mining, log file analysis, machine learning, scientific simulation, and data warehouse management. For the AWS API documentation, see L =head1 METHODS =head2 AddInstanceFleet =over =item ClusterId => Str =item InstanceFleet => L =back Each argument is described in detail in: L Returns: a L instance Adds an instance fleet to a running cluster. The instance fleet configuration is available only in Amazon EMR versions 4.8.0 and later, excluding 5.0.x. =head2 AddInstanceGroups =over =item InstanceGroups => ArrayRef[L] =item JobFlowId => Str =back Each argument is described in detail in: L Returns: a L instance Adds one or more instance groups to a running cluster. =head2 AddJobFlowSteps =over =item JobFlowId => Str =item Steps => ArrayRef[L] =back Each argument is described in detail in: L Returns: a L instance AddJobFlowSteps adds new steps to a running cluster. A maximum of 256 steps are allowed in each job flow. If your cluster is long-running (such as a Hive data warehouse) or complex, you may require more than 256 steps to process your data. You can bypass the 256-step limitation in various ways, including using SSH to connect to the master node and submitting queries directly to the software running on the master node, such as Hive and Hadoop. For more information on how to do this, see Add More than 256 Steps to a Cluster (https://docs.aws.amazon.com/emr/latest/ManagementGuide/AddMoreThan256Steps.html) in the I. A step specifies the location of a JAR file stored either on the master node of the cluster or in Amazon S3. Each step is performed by the main function of the main class of the JAR file. The main class can be specified either in the manifest of the JAR or by using the MainFunction parameter of the step. Amazon EMR executes each step in the order listed. For a step to be considered complete, the main function must exit with a zero exit code and all Hadoop jobs started while the step was running must have completed and run successfully. You can only add steps to a cluster that is in one of the following states: STARTING, BOOTSTRAPPING, RUNNING, or WAITING. =head2 AddTags =over =item ResourceId => Str =item Tags => ArrayRef[L] =back Each argument is described in detail in: L Returns: a L instance Adds tags to an Amazon EMR resource. Tags make it easier to associate clusters in various ways, such as grouping clusters to track your Amazon EMR resource allocation costs. For more information, see Tag Clusters (https://docs.aws.amazon.com/emr/latest/ManagementGuide/emr-plan-tags.html). =head2 CancelSteps =over =item ClusterId => Str =item StepIds => ArrayRef[Str|Undef] =item [StepCancellationOption => Str] =back Each argument is described in detail in: L Returns: a L instance Cancels a pending step or steps in a running cluster. Available only in Amazon EMR versions 4.8.0 and later, excluding version 5.0.0. A maximum of 256 steps are allowed in each CancelSteps request. CancelSteps is idempotent but asynchronous; it does not guarantee that a step will be canceled, even if the request is successfully submitted. You can only cancel steps that are in a C state. =head2 CreateSecurityConfiguration =over =item Name => Str =item SecurityConfiguration => Str =back Each argument is described in detail in: L Returns: a L instance Creates a security configuration, which is stored in the service and can be specified when a cluster is created. =head2 CreateStudio =over =item AuthMode => Str =item DefaultS3Location => Str =item EngineSecurityGroupId => Str =item Name => Str =item ServiceRole => Str =item SubnetIds => ArrayRef[Str|Undef] =item UserRole => Str =item VpcId => Str =item WorkspaceSecurityGroupId => Str =item [Description => Str] =item [Tags => ArrayRef[L]] =back Each argument is described in detail in: L Returns: a L instance Creates a new Amazon EMR Studio. =head2 CreateStudioSessionMapping =over =item IdentityType => Str =item SessionPolicyArn => Str =item StudioId => Str =item [IdentityId => Str] =item [IdentityName => Str] =back Each argument is described in detail in: L Returns: nothing Maps a user or group to the Amazon EMR Studio specified by C, and applies a session policy to refine Studio permissions for that user or group. =head2 DeleteSecurityConfiguration =over =item Name => Str =back Each argument is described in detail in: L Returns: a L instance Deletes a security configuration. =head2 DeleteStudio =over =item StudioId => Str =back Each argument is described in detail in: L Returns: nothing Removes an Amazon EMR Studio from the Studio metadata store. =head2 DeleteStudioSessionMapping =over =item IdentityType => Str =item StudioId => Str =item [IdentityId => Str] =item [IdentityName => Str] =back Each argument is described in detail in: L Returns: nothing Removes a user or group from an Amazon EMR Studio. =head2 DescribeCluster =over =item ClusterId => Str =back Each argument is described in detail in: L Returns: a L instance Provides cluster-level details including status, hardware and software configuration, VPC settings, and so on. =head2 DescribeJobFlows =over =item [CreatedAfter => Str] =item [CreatedBefore => Str] =item [JobFlowIds => ArrayRef[Str|Undef]] =item [JobFlowStates => ArrayRef[Str|Undef]] =back Each argument is described in detail in: L Returns: a L instance This API is no longer supported and will eventually be removed. We recommend you use ListClusters, DescribeCluster, ListSteps, ListInstanceGroups and ListBootstrapActions instead. DescribeJobFlows returns a list of job flows that match all of the supplied parameters. The parameters can include a list of job flow IDs, job flow states, and restrictions on job flow creation date and time. Regardless of supplied parameters, only job flows created within the last two months are returned. If no parameters are supplied, then job flows matching either of the following criteria are returned: =over =item * Job flows created and completed in the last two weeks =item * Job flows created within the last two months that are in one of the following states: C, C, C, C =back Amazon EMR can return a maximum of 512 job flow descriptions. =head2 DescribeNotebookExecution =over =item NotebookExecutionId => Str =back Each argument is described in detail in: L Returns: a L instance Provides details of a notebook execution. =head2 DescribeSecurityConfiguration =over =item Name => Str =back Each argument is described in detail in: L Returns: a L instance Provides the details of a security configuration by returning the configuration JSON. =head2 DescribeStep =over =item ClusterId => Str =item StepId => Str =back Each argument is described in detail in: L Returns: a L instance Provides more detail about the cluster step. =head2 DescribeStudio =over =item StudioId => Str =back Each argument is described in detail in: L Returns: a L instance Returns details for the specified Amazon EMR Studio including ID, Name, VPC, Studio access URL, and so on. =head2 GetBlockPublicAccessConfiguration Each argument is described in detail in: L Returns: a L instance Returns the Amazon EMR block public access configuration for your AWS account in the current Region. For more information see Configure Block Public Access for Amazon EMR (https://docs.aws.amazon.com/emr/latest/ManagementGuide/configure-block-public-access.html) in the I. =head2 GetManagedScalingPolicy =over =item ClusterId => Str =back Each argument is described in detail in: L Returns: a L instance Fetches the attached managed scaling policy for an Amazon EMR cluster. =head2 GetStudioSessionMapping =over =item IdentityType => Str =item StudioId => Str =item [IdentityId => Str] =item [IdentityName => Str] =back Each argument is described in detail in: L Returns: a L instance Fetches mapping details for the specified Amazon EMR Studio and identity (user or group). =head2 ListBootstrapActions =over =item ClusterId => Str =item [Marker => Str] =back Each argument is described in detail in: L Returns: a L instance Provides information about the bootstrap actions associated with a cluster. =head2 ListClusters =over =item [ClusterStates => ArrayRef[Str|Undef]] =item [CreatedAfter => Str] =item [CreatedBefore => Str] =item [Marker => Str] =back Each argument is described in detail in: L Returns: a L instance Provides the status of all clusters visible to this AWS account. Allows you to filter the list of clusters based on certain criteria; for example, filtering by cluster creation date and time or by status. This call returns a maximum of 50 clusters per call, but returns a marker to track the paging of the cluster list across multiple ListClusters calls. =head2 ListInstanceFleets =over =item ClusterId => Str =item [Marker => Str] =back Each argument is described in detail in: L Returns: a L instance Lists all available details about the instance fleets in a cluster. The instance fleet configuration is available only in Amazon EMR versions 4.8.0 and later, excluding 5.0.x versions. =head2 ListInstanceGroups =over =item ClusterId => Str =item [Marker => Str] =back Each argument is described in detail in: L Returns: a L instance Provides all available details about the instance groups in a cluster. =head2 ListInstances =over =item ClusterId => Str =item [InstanceFleetId => Str] =item [InstanceFleetType => Str] =item [InstanceGroupId => Str] =item [InstanceGroupTypes => ArrayRef[Str|Undef]] =item [InstanceStates => ArrayRef[Str|Undef]] =item [Marker => Str] =back Each argument is described in detail in: L Returns: a L instance Provides information for all active EC2 instances and EC2 instances terminated in the last 30 days, up to a maximum of 2,000. EC2 instances in any of the following states are considered active: AWAITING_FULFILLMENT, PROVISIONING, BOOTSTRAPPING, RUNNING. =head2 ListNotebookExecutions =over =item [EditorId => Str] =item [From => Str] =item [Marker => Str] =item [Status => Str] =item [To => Str] =back Each argument is described in detail in: L Returns: a L instance Provides summaries of all notebook executions. You can filter the list based on multiple criteria such as status, time range, and editor id. Returns a maximum of 50 notebook executions and a marker to track the paging of a longer notebook execution list across multiple C calls. =head2 ListSecurityConfigurations =over =item [Marker => Str] =back Each argument is described in detail in: L Returns: a L instance Lists all the security configurations visible to this account, providing their creation dates and times, and their names. This call returns a maximum of 50 clusters per call, but returns a marker to track the paging of the cluster list across multiple ListSecurityConfigurations calls. =head2 ListSteps =over =item ClusterId => Str =item [Marker => Str] =item [StepIds => ArrayRef[Str|Undef]] =item [StepStates => ArrayRef[Str|Undef]] =back Each argument is described in detail in: L Returns: a L instance Provides a list of steps for the cluster in reverse order unless you specify C with the request of filter by C. You can specify a maximum of 10 C. =head2 ListStudios =over =item [Marker => Str] =back Each argument is described in detail in: L Returns: a L instance Returns a list of all Amazon EMR Studios associated with the AWS account. The list includes details such as ID, Studio Access URL, and creation time for each Studio. =head2 ListStudioSessionMappings =over =item [IdentityType => Str] =item [Marker => Str] =item [StudioId => Str] =back Each argument is described in detail in: L Returns: a L instance Returns a list of all user or group session mappings for the Amazon EMR Studio specified by C. =head2 ModifyCluster =over =item ClusterId => Str =item [StepConcurrencyLevel => Int] =back Each argument is described in detail in: L Returns: a L instance Modifies the number of steps that can be executed concurrently for the cluster specified using ClusterID. =head2 ModifyInstanceFleet =over =item ClusterId => Str =item InstanceFleet => L =back Each argument is described in detail in: L Returns: nothing Modifies the target On-Demand and target Spot capacities for the instance fleet with the specified InstanceFleetID within the cluster specified using ClusterID. The call either succeeds or fails atomically. The instance fleet configuration is available only in Amazon EMR versions 4.8.0 and later, excluding 5.0.x versions. =head2 ModifyInstanceGroups =over =item [ClusterId => Str] =item [InstanceGroups => ArrayRef[L]] =back Each argument is described in detail in: L Returns: nothing ModifyInstanceGroups modifies the number of nodes and configuration settings of an instance group. The input parameters include the new target instance count for the group and the instance group ID. The call will either succeed or fail atomically. =head2 PutAutoScalingPolicy =over =item AutoScalingPolicy => L =item ClusterId => Str =item InstanceGroupId => Str =back Each argument is described in detail in: L Returns: a L instance Creates or updates an automatic scaling policy for a core instance group or task instance group in an Amazon EMR cluster. The automatic scaling policy defines how an instance group dynamically adds and terminates EC2 instances in response to the value of a CloudWatch metric. =head2 PutBlockPublicAccessConfiguration =over =item BlockPublicAccessConfiguration => L =back Each argument is described in detail in: L Returns: a L instance Creates or updates an Amazon EMR block public access configuration for your AWS account in the current Region. For more information see Configure Block Public Access for Amazon EMR (https://docs.aws.amazon.com/emr/latest/ManagementGuide/configure-block-public-access.html) in the I. =head2 PutManagedScalingPolicy =over =item ClusterId => Str =item ManagedScalingPolicy => L =back Each argument is described in detail in: L Returns: a L instance Creates or updates a managed scaling policy for an Amazon EMR cluster. The managed scaling policy defines the limits for resources, such as EC2 instances that can be added or terminated from a cluster. The policy only applies to the core and task nodes. The master node cannot be scaled after initial configuration. =head2 RemoveAutoScalingPolicy =over =item ClusterId => Str =item InstanceGroupId => Str =back Each argument is described in detail in: L Returns: a L instance Removes an automatic scaling policy from a specified instance group within an EMR cluster. =head2 RemoveManagedScalingPolicy =over =item ClusterId => Str =back Each argument is described in detail in: L Returns: a L instance Removes a managed scaling policy from a specified EMR cluster. =head2 RemoveTags =over =item ResourceId => Str =item TagKeys => ArrayRef[Str|Undef] =back Each argument is described in detail in: L Returns: a L instance Removes tags from an Amazon EMR resource. Tags make it easier to associate clusters in various ways, such as grouping clusters to track your Amazon EMR resource allocation costs. For more information, see Tag Clusters (https://docs.aws.amazon.com/emr/latest/ManagementGuide/emr-plan-tags.html). The following example removes the stack tag with value Prod from a cluster: =head2 RunJobFlow =over =item Instances => L =item Name => Str =item [AdditionalInfo => Str] =item [AmiVersion => Str] =item [Applications => ArrayRef[L]] =item [AutoScalingRole => Str] =item [BootstrapActions => ArrayRef[L]] =item [Configurations => ArrayRef[L]] =item [CustomAmiId => Str] =item [EbsRootVolumeSize => Int] =item [JobFlowRole => Str] =item [KerberosAttributes => L] =item [LogEncryptionKmsKeyId => Str] =item [LogUri => Str] =item [ManagedScalingPolicy => L] =item [NewSupportedProducts => ArrayRef[L]] =item [PlacementGroupConfigs => ArrayRef[L]] =item [ReleaseLabel => Str] =item [RepoUpgradeOnBoot => Str] =item [ScaleDownBehavior => Str] =item [SecurityConfiguration => Str] =item [ServiceRole => Str] =item [StepConcurrencyLevel => Int] =item [Steps => ArrayRef[L]] =item [SupportedProducts => ArrayRef[Str|Undef]] =item [Tags => ArrayRef[L]] =item [VisibleToAllUsers => Bool] =back Each argument is described in detail in: L Returns: a L instance RunJobFlow creates and starts running a new cluster (job flow). The cluster runs the steps specified. After the steps complete, the cluster stops and the HDFS partition is lost. To prevent loss of data, configure the last step of the job flow to store results in Amazon S3. If the JobFlowInstancesConfig C parameter is set to C, the cluster transitions to the WAITING state rather than shutting down after the steps have completed. For additional protection, you can set the JobFlowInstancesConfig C parameter to C to lock the cluster and prevent it from being terminated by API call, user intervention, or in the event of a job flow error. A maximum of 256 steps are allowed in each job flow. If your cluster is long-running (such as a Hive data warehouse) or complex, you may require more than 256 steps to process your data. You can bypass the 256-step limitation in various ways, including using the SSH shell to connect to the master node and submitting queries directly to the software running on the master node, such as Hive and Hadoop. For more information on how to do this, see Add More than 256 Steps to a Cluster (https://docs.aws.amazon.com/emr/latest/ManagementGuide/AddMoreThan256Steps.html) in the I. For long running clusters, we recommend that you periodically store your results. The instance fleets configuration is available only in Amazon EMR versions 4.8.0 and later, excluding 5.0.x versions. The RunJobFlow request can contain InstanceFleets parameters or InstanceGroups parameters, but not both. =head2 SetTerminationProtection =over =item JobFlowIds => ArrayRef[Str|Undef] =item TerminationProtected => Bool =back Each argument is described in detail in: L Returns: nothing SetTerminationProtection locks a cluster (job flow) so the EC2 instances in the cluster cannot be terminated by user intervention, an API call, or in the event of a job-flow error. The cluster still terminates upon successful completion of the job flow. Calling C on a cluster is similar to calling the Amazon EC2 C API on all EC2 instances in a cluster. C is used to prevent accidental termination of a cluster and to ensure that in the event of an error, the instances persist so that you can recover any data stored in their ephemeral instance storage. To terminate a cluster that has been locked by setting C to C, you must first unlock the job flow by a subsequent call to C in which you set the value to C. For more information, seeManaging Cluster Termination (https://docs.aws.amazon.com/emr/latest/ManagementGuide/UsingEMR_TerminationProtection.html) in the I. =head2 SetVisibleToAllUsers =over =item JobFlowIds => ArrayRef[Str|Undef] =item VisibleToAllUsers => Bool =back Each argument is described in detail in: L Returns: nothing Sets the Cluster$VisibleToAllUsers value, which determines whether the cluster is visible to all IAM users of the AWS account associated with the cluster. Only the IAM user who created the cluster or the AWS account root user can call this action. The default value, C, indicates that all IAM users in the AWS account can perform cluster actions if they have the proper IAM policy permissions. If set to C, only the IAM user that created the cluster can perform actions. This action works on running clusters. You can override the default C setting when you create a cluster by using the C parameter with C. =head2 StartNotebookExecution =over =item EditorId => Str =item ExecutionEngine => L =item RelativePath => Str =item ServiceRole => Str =item [NotebookExecutionName => Str] =item [NotebookInstanceSecurityGroupId => Str] =item [NotebookParams => Str] =item [Tags => ArrayRef[L]] =back Each argument is described in detail in: L Returns: a L instance Starts a notebook execution. =head2 StopNotebookExecution =over =item NotebookExecutionId => Str =back Each argument is described in detail in: L Returns: nothing Stops a notebook execution. =head2 TerminateJobFlows =over =item JobFlowIds => ArrayRef[Str|Undef] =back Each argument is described in detail in: L Returns: nothing TerminateJobFlows shuts a list of clusters (job flows) down. When a job flow is shut down, any step not yet completed is canceled and the EC2 instances on which the cluster is running are stopped. Any log files not already saved are uploaded to Amazon S3 if a LogUri was specified when the cluster was created. The maximum number of clusters allowed is 10. The call to C is asynchronous. Depending on the configuration of the cluster, it may take up to 1-5 minutes for the cluster to completely terminate and release allocated resources, such as Amazon EC2 instances. =head2 UpdateStudio =over =item StudioId => Str =item [DefaultS3Location => Str] =item [Description => Str] =item [Name => Str] =item [SubnetIds => ArrayRef[Str|Undef]] =back Each argument is described in detail in: L Returns: nothing Updates an Amazon EMR Studio configuration, including attributes such as name, description, and subnets. =head2 UpdateStudioSessionMapping =over =item IdentityType => Str =item SessionPolicyArn => Str =item StudioId => Str =item [IdentityId => Str] =item [IdentityName => Str] =back Each argument is described in detail in: L Returns: nothing Updates the session policy attached to the user or group for the specified Amazon EMR Studio. =head1 PAGINATORS Paginator methods are helpers that repetively call methods that return partial results =head2 ListAllBootstrapActions(sub { },ClusterId => Str, [Marker => Str]) =head2 ListAllBootstrapActions(ClusterId => Str, [Marker => Str]) If passed a sub as first parameter, it will call the sub for each element found in : - BootstrapActions, passing the object as the first parameter, and the string 'BootstrapActions' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head2 ListAllClusters(sub { },[ClusterStates => ArrayRef[Str|Undef], CreatedAfter => Str, CreatedBefore => Str, Marker => Str]) =head2 ListAllClusters([ClusterStates => ArrayRef[Str|Undef], CreatedAfter => Str, CreatedBefore => Str, Marker => Str]) If passed a sub as first parameter, it will call the sub for each element found in : - Clusters, passing the object as the first parameter, and the string 'Clusters' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head2 ListAllInstanceFleets(sub { },ClusterId => Str, [Marker => Str]) =head2 ListAllInstanceFleets(ClusterId => Str, [Marker => Str]) If passed a sub as first parameter, it will call the sub for each element found in : - InstanceFleets, passing the object as the first parameter, and the string 'InstanceFleets' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head2 ListAllInstanceGroups(sub { },ClusterId => Str, [Marker => Str]) =head2 ListAllInstanceGroups(ClusterId => Str, [Marker => Str]) If passed a sub as first parameter, it will call the sub for each element found in : - InstanceGroups, passing the object as the first parameter, and the string 'InstanceGroups' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head2 ListAllInstances(sub { },ClusterId => Str, [InstanceFleetId => Str, InstanceFleetType => Str, InstanceGroupId => Str, InstanceGroupTypes => ArrayRef[Str|Undef], InstanceStates => ArrayRef[Str|Undef], Marker => Str]) =head2 ListAllInstances(ClusterId => Str, [InstanceFleetId => Str, InstanceFleetType => Str, InstanceGroupId => Str, InstanceGroupTypes => ArrayRef[Str|Undef], InstanceStates => ArrayRef[Str|Undef], Marker => Str]) If passed a sub as first parameter, it will call the sub for each element found in : - Instances, passing the object as the first parameter, and the string 'Instances' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head2 ListAllNotebookExecutions(sub { },[EditorId => Str, From => Str, Marker => Str, Status => Str, To => Str]) =head2 ListAllNotebookExecutions([EditorId => Str, From => Str, Marker => Str, Status => Str, To => Str]) If passed a sub as first parameter, it will call the sub for each element found in : - NotebookExecutions, passing the object as the first parameter, and the string 'NotebookExecutions' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head2 ListAllSecurityConfigurations(sub { },[Marker => Str]) =head2 ListAllSecurityConfigurations([Marker => Str]) If passed a sub as first parameter, it will call the sub for each element found in : - SecurityConfigurations, passing the object as the first parameter, and the string 'SecurityConfigurations' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head2 ListAllSteps(sub { },ClusterId => Str, [Marker => Str, StepIds => ArrayRef[Str|Undef], StepStates => ArrayRef[Str|Undef]]) =head2 ListAllSteps(ClusterId => Str, [Marker => Str, StepIds => ArrayRef[Str|Undef], StepStates => ArrayRef[Str|Undef]]) If passed a sub as first parameter, it will call the sub for each element found in : - Steps, passing the object as the first parameter, and the string 'Steps' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head2 ListAllStudios(sub { },[Marker => Str]) =head2 ListAllStudios([Marker => Str]) If passed a sub as first parameter, it will call the sub for each element found in : - Studios, passing the object as the first parameter, and the string 'Studios' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head2 ListAllStudioSessionMappings(sub { },[IdentityType => Str, Marker => Str, StudioId => Str]) =head2 ListAllStudioSessionMappings([IdentityType => Str, Marker => Str, StudioId => Str]) If passed a sub as first parameter, it will call the sub for each element found in : - SessionMappings, passing the object as the first parameter, and the string 'SessionMappings' as the second parameter If not, it will return a a L instance with all the Cs; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory. =head1 SEE ALSO This service class forms part of L =head1 BUGS and CONTRIBUTIONS The source code is located here: L Please report bugs to: L =cut